最?lèi)?ài)Java

          書(shū)山有路勤為徑,學(xué)海無(wú)涯苦作舟

          javascript面向?qū)ο蠹夹g(shù)基礎(chǔ)(一)

                    本文轉(zhuǎn)載于javaeye(http://www.javaeye.com/wiki/Object_Oriented_JavaScript/1279-javascript-object-oriented-technology-one),只進(jìn)行了重新排版以便收藏。
                    文中所有英文語(yǔ)句(程序語(yǔ)句除外),都引自<<javascript-the definitive guide,5th edition>>。

          ------------------------------------------------------------------------------------
          對(duì)象和數(shù)組(Objects and Arrays)
                  什么是對(duì)象?把一些"名字-屬性"的組合放在一個(gè)單元里面,就組成了一個(gè)對(duì)象。我們可以理解為javascript中的對(duì)象就是一些"鍵-值"對(duì)的集合(An object is a collection of named values. These named values are usually referred to as properties of the object.--Section3.5)。
                  "名字"只能是string類(lèi)型,不能是其他類(lèi)型,而屬性的類(lèi)型則是任意的(數(shù)字/字符串/其他對(duì)象..)。可以用new Object()來(lái)創(chuàng)建一個(gè)空對(duì)象,也可以簡(jiǎn)單的用"{}"來(lái)創(chuàng)建一個(gè)空對(duì)象,這兩者的作用是等同的。
                   
          1var emptyObject1 = {};           //創(chuàng)建空對(duì)象   
          2var emptyObject2 = new Object(); //創(chuàng)建空對(duì)象   
          3var person = {"name":"sdcyst",   
          4          "age":18,   
          5          "sex":"male"}
          ;     //創(chuàng)建一個(gè)包含初始值的對(duì)象person   
          6alert(person.name);              //sdcyst   
          7alert(person["age"]);            //18  
              
                  從上面的例子我們也可以看到,訪問(wèn)一個(gè)對(duì)象的屬性,可以簡(jiǎn)單的用對(duì)象名加"."后加屬性的名字,也可以用"[]"操作符來(lái)獲取,此時(shí)在[]里面的屬性名字要加引號(hào),這是因?yàn)閷?duì)象中的索引都是字符串類(lèi)型的。javasript對(duì)象中屬性的個(gè)數(shù)是可變的,在創(chuàng)建了一個(gè)對(duì)象之后可以隨時(shí)對(duì)它賦予任何的屬性。

          1var person = {};   
          2person.name = "sdcyst";   
          3person["age"= 18;   
          4alert(person.name + "__" + person.age); //sdcyst__18   
          5  
          6var _person = {name:"balala","age":23}//在構(gòu)建一個(gè)對(duì)象時(shí),屬性的名字可以不用引號(hào)來(lái)標(biāo)注(name),   
          7                    //但是仍舊是一個(gè)字符串類(lèi)型.在訪問(wèn)的時(shí)候[]內(nèi)仍舊需要引號(hào)   
          8alert(_person["name"+ "__" + person.age); //balala__23   
          9alert(_person[name]);                   //undefinied  
             
                  通過(guò)"."操作符獲取對(duì)象的屬性,必須得知道屬性的名字。一般來(lái)說(shuō)"[]"操作符獲取對(duì)象屬性的功能更強(qiáng)大一些,可以在[]中放入一些表達(dá)式來(lái)取屬性的值,比如可以用在循環(huán)控制語(yǔ)句中,而"."操作符則沒(méi)有這種靈活性。

           1var name = {"name1":"NAME1","name2":"NAME2","name3":"NAME3","name4":"NAME4"};   
           2var namestring = "";   
           3for(var props in name) {  //循環(huán)name對(duì)象中的屬性名字   
           4    namestring += name[props];   
           5}
             
           6alert(namestring);  //NAME1NAME2NAME3NAME4   
           7  
           8namestring = "";   
           9for(var i=0; i<4; i++{   
          10    namestring += name["name"+(i+1)];   
          11}
             
          12alert(namestring);  //NAME1NAME2NAME3NAME4  

                  delete操作符可以刪除對(duì)象中的某個(gè)屬性,判斷某個(gè)屬性是否存在可以使用"in"操作符。

           1var name = {"name1":"NAME1","name2":"NAME2","name3":"NAME3","name4":"NAME4"};   
           2var namestring = "";   
           3for(var props in name) {  //循環(huán)name對(duì)象中的屬性名字   
           4    namestring += name[props];   
           5}
             
           6alert(namestring);  //NAME1NAME2NAME3NAME4   
           7  
           8delete name.name1;  //刪除name1屬性   
           9delete name["name3"];  //刪除name3屬性   
          10namestring = "";   
          11for(var props in name) {  //循環(huán)name對(duì)象中的屬性名字   
          12    namestring += name[props];   
          13}
             
          14alert(namestring);  //NAME2NAME4   
          15  
          16alert("name1" in name); //false   
          17alert("name4" in name); //true  

                  需要注意,對(duì)象中的屬性是沒(méi)有順序的。

          對(duì)象的constructor屬性
                  每一個(gè)javascript對(duì)象都有一個(gè)constructor屬性。這個(gè)屬性對(duì)應(yīng)了對(duì)象初始化時(shí)的構(gòu)造函數(shù)(函數(shù)也是對(duì)象)。

          1var date = new Date();   
          2alert(date.constructor);  //Date   
          3alert(date.constructor == "Date");  //false   
          4alert(date.constructor == Date);  //true  

          posted on 2009-10-20 10:37 Brian 閱讀(241) 評(píng)論(0)  編輯  收藏 所屬分類(lèi): JScript

          公告


          導(dǎo)航

          <2009年10月>
          27282930123
          45678910
          11121314151617
          18192021222324
          25262728293031
          1234567

          統(tǒng)計(jì)

          常用鏈接

          留言簿(4)

          隨筆分類(lèi)

          隨筆檔案

          收藏夾

          搜索

          最新評(píng)論

          閱讀排行榜

          評(píng)論排行榜

          主站蜘蛛池模板: 普洱| 玉林市| 孝昌县| 柘城县| 柞水县| 景泰县| 中西区| 吉木萨尔县| 荣成市| 太湖县| 海丰县| 丰原市| 班玛县| 宁安市| 灵山县| 台湾省| 云霄县| 长治县| 雷山县| 金秀| 贵德县| 新闻| 新河县| 东山县| 涿鹿县| 安国市| 道真| 西乌珠穆沁旗| 白山市| 武功县| 封开县| 高唐县| 女性| 黄陵县| 诸城市| 莎车县| 安岳县| 昌图县| 惠来县| 南涧| 灵丘县|