使用變量動態(tài)設(shè)置js的屬性名
來源:易賢網(wǎng) 閱讀:4619 次 日期:2014-11-03 14:48:37
溫馨提示:易賢網(wǎng)小編為您整理了“使用變量動態(tài)設(shè)置js的屬性名”,方便廣大網(wǎng)友查閱!

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

舉例:js對象object,當賦給該對象屬性的時候可以采用以下方式

代碼如下:

var object;

object.prop1 = "value1";

object.prop2 = "value2";

也可以采用如下方式:

代碼如下:

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

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

在這里prop1 作為屬性名稱,可以直接用,也可以加上引號,比如:

代碼如下:

object.push({"<span style="font-family: Arial, Helvetica, sans-serif;">prop1</span>":"value1"});

表達的含義都是一樣的,也就是說,prop1只能作為常量被識別,即使它是個變量也沒用,例如:

代碼如下:

var prop1 = "prop2";

object.push({prop1:"<span style="font-family: Arial, Helvetica, sans-serif;">value1</span>"});

這樣通過object訪問prop2會出現(xiàn)什么情況呢?比如:

代碼如下:

alert(<span style="font-family: Arial, Helvetica, sans-serif;">object.prop2) </span>

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

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

代碼如下:

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現(xiàn)在只有一個屬性i,而且通過兩次循環(huán),obj.i前面的被后面的覆蓋掉.

如果有需求,需要動態(tà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當成一個數(shù)組來對待,它支持使用類似于下標形式的方法來把屬性和屬性值賦給對象.但是,對象依然是對象,obj.length是不存在的.

更多信息請查看IT技術(shù)專欄

更多信息請查看腳本欄目
易賢網(wǎng)手機網(wǎng)站地址:使用變量動態(tài)設(shè)置js的屬性名

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 加入群交流 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
咨詢QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)