亚洲免费乱码视频,日韩 欧美 国产 动漫 一区,97在线观看免费视频播国产,中文字幕亚洲图片

      1. <legend id="ppnor"></legend>

      2. 
        
        <sup id="ppnor"><input id="ppnor"></input></sup>
        <s id="ppnor"></s>

        使用變量動態(tài)設置js的屬性名

        字號:


            目標:js的屬性名可以使用變量
            舉例:js對象object,當賦給該對象屬性的時候可以采用以下方式
            代碼如下:
            var object;
            object.prop1 = "value1";
            object.prop2 = "value2";
            也可以采用如下方式:
            代碼如下:
            object.push({prop1:"value1"});
            object.push({prop2:"value2"});
            在這里prop1 作為屬性名稱,可以直接用,也可以加上引號,比如:
            代碼如下:
            object.push({"<span>prop1</span>":"value1"});
            表達的含義都是一樣的,也就是說,prop1只能作為常量被識別,即使它是個變量也沒用,例如:
            代碼如下:
            var prop1 = "prop2";
            object.push({prop1:"<span>value1</span>"});
            這樣通過object訪問prop2會出現什么情況呢?比如:
            代碼如下:
            alert(<span>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,而且通過兩次循環(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當成一個數組來對待,它支持使用類似于下標形式的方法來把屬性和屬性值賦給對象.但是,對象依然是對象,obj.length是不存在的.