国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

使用變量動態設置js的屬性名

2024-05-06 16:09:54
字體:
來源:轉載
供稿:網友
js的屬性名可以使用變量,例如js對象object,當賦給該對象屬性的時候可以采用以下方式,比較實用,需要的朋友可以看看
 
 

目標: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會出現什么情況呢?比如: 
復制代碼代碼如下:

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

不用問,當然是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是不存在的. 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 井冈山市| 兴山县| 谢通门县| 阿荣旗| 盖州市| 宁南县| 濮阳县| 阳曲县| 阿尔山市| 章丘市| 昌平区| 综艺| 茌平县| 托克托县| 达尔| 泰来县| 岳普湖县| 内江市| 湾仔区| 苍梧县| 清新县| 云龙县| 通江县| 津市市| 仙居县| 彰化市| 宁安市| 资中县| 永寿县| 静安区| 娄烦县| 阳泉市| 泗阳县| 琼海市| 紫云| 秀山| 新昌县| 莎车县| 会泽县| 民勤县| 镇宁|