首頁 > web前端 > js教程 > 主體

使用變數動態設定js的屬性名_javascript技巧

WBOY
發布: 2016-05-16 16:33:28
原創
1526 人瀏覽過

目標:js的屬性名稱可以使用變數

舉例:js物件object,當賦給該物件屬性的時候可以採用以下方式

複製程式碼 程式碼如下:

var object;
object.prop1 = "value1";
object.prop2 = "value2";

也可以採用以下方式:
複製程式碼 程式碼如下:

object.push({prop1:"value1"});
object.push({prop2:"value2"});

這裡prop1 作為屬性名稱,可以直接用,也可以加上引號,比如:
複製程式碼 程式碼如下:

object.push({"prop1":"value1"});

表達的意思都是一樣的,也就是說,prop1只能作為常數被識別,即使它是個變數也沒用,例如:
複製程式碼 程式碼如下:

var prop1 = "prop2";
object.push({prop1:"value1"});

這樣透過object存取prop2會出現什麼情況呢?例如:
複製程式碼 程式碼如下:

alert(object.prop2)

不用問,當然是undefined,而訪問object.prop1卻是"value1"

原因已經說過了,無論加不加引號,屬性一律當成常量對待.再舉一個例子:

複製程式碼 程式碼如下:

var arr=[];
arr['js']='jquery';
arr['css']='oocss';
var obj={};
for(var i in arr)
{

obj.i=arr[i];
}
alert(obj.js);

讀者不放猜一下alert會印什麼?

當然是undefined.

大家再猜一下,如果alert(obj.i)會印什麼?

當然是oocss,為什麼?因為obj現在只有一個屬性i,而且透過兩次循環,obj.i前面的被後面的覆蓋掉.

如果有需求,需要動態加入屬性,也就是說,屬性也必須是變數才行,如上例程式碼,alert(obj.js)不是undefined,而是jquery,該如何修改呢?

複製程式碼 程式碼如下:

var arr=[];
arr['js']='jquery';
arr['css']='oocss';
var obj={};
for(var i in arr)
{

obj[i]=arr[i];
}
alert(obj.js);


就是那麼簡單!把物件obj當成一個陣列來對待,它支援使用類似於下標形式的方法來把屬性和屬性值賦給物件.但是,物件依然是物件,obj.length是不存在的.
相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!