中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術(shù)文檔 > 網(wǎng)頁制作 > 悟透JavaScript
標記語言——短語元素 回到列表 標記語言——表單
 悟透JavaScript

作者:李戰(zhàn) 時間: 2008-05-29 文檔類型:轉(zhuǎn)載 來自:軟件真諦

第 1 頁 引子
第 2 頁 回到簡單
第 3 頁 沒有類
第 4 頁 函數(shù)的魔力
第 5 頁 奇妙的對象
第 6 頁 放下對象
第 7 頁 對象素描
第 8 頁 構(gòu)造對象
第 9 頁 初看原型
第 10 頁 原型擴展
第 11 頁 原型真諦
第 12 頁 編程的快樂

構(gòu)造對象

好了,接下我們來討論一下對象的另一種創(chuàng)建方法。

 除JSON外,在JavaScript中我們可以使用new操作符結(jié)合一個函數(shù)的形式來創(chuàng)建對象。例如:

    function MyFunc() {};         //定義一個空函數(shù)
    var anObj = new MyFunc();  //使用new操作符,借助MyFun函數(shù),就創(chuàng)建了一個對象
    JavaScript的這種創(chuàng)建對象的方式可真有意思,如何去理解這種寫法呢?
 
   其實,可以把上面的代碼改寫成這種等價形式:
    function MyFunc(){};
    var anObj = {};     //創(chuàng)建一個對象
    MyFunc.call(anObj); //將anObj對象作為this指針調(diào)用MyFunc函數(shù)

我們就可以這樣理解,JavaScript先用new操作符創(chuàng)建了一個對象,緊接著就將這個對象作為this參數(shù)調(diào)用了后面的函數(shù)。其實,JavaScript內(nèi)部就是這么做的,而且任何函數(shù)都可以被這樣調(diào)用!但從 “anObj = new MyFunc()” 這種形式,我們又看到一個熟悉的身影,C++和C#不就是這樣創(chuàng)建對象的嗎?原來,條條大路通靈山,殊途同歸啊!

君看到此處也許會想,我們?yōu)槭裁床豢梢园堰@個MyFunc當作構(gòu)造函數(shù)呢?恭喜你,答對了!JavaScript也是這么想的!請看下面的代碼: 

 1     function Person(name)   //帶參數(shù)的構(gòu)造函數(shù)
 2     {
 3         this.name = name;   //將參數(shù)值賦給給this對象的屬性
 4         this.SayHello = function() {alert("Hello, I'm " + this.name);};   //給this對象定義一個SayHello方法。
 5     };
 6
 7     function Employee(name, salary)     //子構(gòu)造函數(shù)
 8     {
 9         Person.call(this, name);        //將this傳給父構(gòu)造函數(shù)
10         this.salary = salary;       //設置一個this的salary屬性
11         this.ShowMeTheMoney = function() {alert(this.name + " $" + this.salary);};  //添加ShowMeTheMoney方法。
12     };
13    
14     var BillGates = new Person("Bill Gates");   //用Person構(gòu)造函數(shù)創(chuàng)建BillGates對象
15     var SteveJobs = new Employee("Steve Jobs", 1234);   //用Empolyee構(gòu)造函數(shù)創(chuàng)建SteveJobs對象
16
17     BillGates.SayHello();   //顯示:I'm Bill Gates
18     SteveJobs.SayHello();   //顯示:I'm Steve Jobs
19     SteveJobs.ShowMeTheMoney();   //顯示:Steve Jobs $1234
20
21     alert(BillGates.constructor == Person);  //顯示:true
22     alert(SteveJobs.constructor == Employee);  //顯示:true
23    
24     alert(BillGates.SayHello == SteveJobs.SayHello); //顯示:false

這段代碼表明,函數(shù)不但可以當作構(gòu)造函數(shù),而且還可以帶參數(shù),還可以為對象添加成員和方法。其中的第9行,Employee構(gòu)造函數(shù)又將自己接收的this作為參數(shù)調(diào)用Person構(gòu)造函數(shù),這就是相當于調(diào)用基類的構(gòu)造函數(shù)。第21、22行還表明這樣一個意思:BillGates是由Person構(gòu)造的,而SteveJobs是由Employee構(gòu)造的。對象內(nèi)置的constructor屬性還指明了構(gòu)造對象所用的具體函數(shù)!

其實,如果你愿意把函數(shù)當作“類”的話,她就是“類”,因為她本來就有“類”的那些特征。難道不是嗎?她生出的兒子各個都有相同的特征,而且構(gòu)造函數(shù)也與類同名嘛!

但要注意的是,用構(gòu)造函數(shù)操作this對象創(chuàng)建出來的每一個對象,不但具有各自的成員數(shù)據(jù),而且還具有各自的方法數(shù)據(jù)。換句話說,方法的代碼體(體現(xiàn)函數(shù)邏輯的數(shù)據(jù))在每一個對象中都存在一個副本。盡管每一個代碼副本的邏輯是相同的,但對象們確實是各自保存了一份代碼體。上例中的最后一句說明了這一實事,這也解釋了JavaScript中的函數(shù)就是對象的概念。

同一類的對象各自有一份方法代碼顯然是一種浪費。在傳統(tǒng)的對象語言中,方法函數(shù)并不象JavaScript那樣是個對象概念。即使也有象函數(shù)指針、方法指針或委托那樣的變化形式,但其實質(zhì)也是對同一份代碼的引用。一般的對象語言很難遇到這種情況。

不過,JavaScript語言有大的靈活性。我們可以先定義一份唯一的方法函數(shù)體,并在構(gòu)造this對象時使用這唯一的函數(shù)對象作為其方法,就能共享方法邏輯。例如:

    function SayHello()     //先定義一份SayHello函數(shù)代碼
    {
        alert("Hello, I'm " + this.name);
    };
   
    function Person(name)   //帶參數(shù)的構(gòu)造函數(shù)
    {
        this.name = name;   //將參數(shù)值賦給給this對象的屬性
        this.SayHello = SayHello;   //給this對象SayHello方法賦值為前面那份SayHello代碼。
    };

    var BillGates = new Person("Bill Gates");   //創(chuàng)建BillGates對象
    var SteveJobs = new Person("Steve Jobs");   //創(chuàng)建SteveJobs對象
   
    alert(BillGates.SayHello == SteveJobs.SayHello); //顯示:true

其中,最后一行的輸出結(jié)果表明兩個對象確實共享了一個函數(shù)對象。雖然,這段程序達到了共享了一份方法代碼的目的,但卻不怎么優(yōu)雅。因為,定義SayHello方法時反映不出其與Person類的關(guān)系!皟(yōu)雅”這個詞用來形容代碼,也不知道是誰先提出來的。不過,這個詞反映了程序員已經(jīng)從追求代碼的正確、高效、可靠和易讀等基礎上,向著追求代碼的美觀感覺和藝術(shù)境界的層次發(fā)展,程序人生又多了些浪漫色彩。

顯然,JavaScript早想到了這一問題,她的設計者們?yōu)榇颂峁┝艘粋有趣的prototype概念。

出處:軟件真諦
責任編輯:moby

上一頁 對象素描 下一頁 初看原型

◎進入論壇網(wǎng)頁制作、WEB標準化版塊參加討論,我還想發(fā)表評論

相關(guān)文章 更多相關(guān)鏈接
Js的MessageBox
Javascript的匿名函數(shù)
也談javascript程序優(yōu)化問題
[js效果]商品分類到搜索欄友好提示
認識延遲時間為0的setTimeout
作者文章
主鍵的故事
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設計比賽 網(wǎng)頁制作 web標準 用戶體驗 UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點最新 站點最新列表
周大!熬•自然”設計大賽開啟
國際體驗設計大會7月將在京舉行
中國國防科技信息中心標志征集
云計算如何讓安全問題可控
云計算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機會
阿里行云
云手機年終巨獻,送禮標配299起
阿里巴巴CTO王堅的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機主題設計大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule
>> 分頁 首頁 前頁 后頁 尾頁 頁次:8/121個記錄/頁 轉(zhuǎn)到 頁 共12個記錄

藍色理想版權(quán)申明:除部分特別聲明不要轉(zhuǎn)載,或者授權(quán)我站獨家播發(fā)的文章外,大家可以自由轉(zhuǎn)載我站點的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權(quán)歸我站和作者共有。

轉(zhuǎn)載要求:轉(zhuǎn)載之圖片、文件,鏈接請不要盜鏈到本站,且不準打上各自站點的水印,亦不能抹去我站點水印。

特別注意:本站所提供的攝影照片,插畫,設計作品,如需使用,請與原作者聯(lián)系,版權(quán)歸原作者所有,文章若有侵犯作者版權(quán),請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會員,你可以注冊 為本站會員。
注意:文章中的鏈接、內(nèi)容等需要修改的錯誤,請用報告錯誤,以利文檔及時修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內(nèi)容無關(guān)的廣告鏈接,違者封ID
請您注意:
·不良評論請用報告管理員,以利管理員及時刪除。
·尊重網(wǎng)上道德,遵守中華人民共和國的各項有關(guān)法律法規(guī)
·承擔一切因您的行為而直接或間接導致的民事或刑事法律責任
·本站評論管理人員有權(quán)保留或刪除其管轄評論中的任意內(nèi)容
·您在本站發(fā)表的作品,本站有權(quán)在網(wǎng)站內(nèi)轉(zhuǎn)載或引用
·參與本評論即表明您已經(jīng)閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報告錯誤  
專業(yè)書推薦 更多內(nèi)容
網(wǎng)站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網(wǎng)站UI 設計之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設計》
犀利開發(fā)—jQuery內(nèi)核詳解與實踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2