欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS創(chuàng)建類和對(duì)象的兩種不同方式

 更新時(shí)間:2014年08月08日 10:06:38   投稿:whsnow  
定義了一個(gè)新的函數(shù), 你實(shí)際上聲明了一個(gè)新的類, 而這個(gè)函數(shù)本身就相當(dāng)于類的構(gòu)造函數(shù),下面為大家展示創(chuàng)建一個(gè)新類的兩種不同方式

在JavaScript中, 當(dāng)你定義了一個(gè)新的函數(shù), 你實(shí)際上聲明了一個(gè)新的類, 而這個(gè)函數(shù)本身就相當(dāng)于類的構(gòu)造函數(shù)。下面的代碼向你展示了兩種不同的方式來(lái)創(chuàng)建一個(gè)新的Person類, 而Person.prototype的定義也緊跟在函數(shù)定義之后。

var Person = function(name) { // 一個(gè)匿名函數(shù), 并將這個(gè)函數(shù)賦值給一個(gè)Person變量, 此時(shí)Person成為一個(gè)類 

this.name = name; 

} 

function Person(name) { // 直接定義一個(gè)叫做Person的函數(shù)表示Person類 

this.name = name; 

} 

Person.prototype = { // 定義Person的prototype域 

printName: function() { // 定義一個(gè)print函數(shù) 

alert(this.name); 

} 

}

當(dāng)你通過(guò)函數(shù)的方式聲明了一個(gè)類之后, 你就可以通過(guò)new操作符來(lái)實(shí)例化這個(gè)類。這樣, 你就可以調(diào)用類的成員函數(shù)來(lái)完成你的邏輯。

var person = new Person("Joe Smith"); // 使用new操作符來(lái)新建一個(gè)Person的實(shí)例, 并賦給變量person 
person.printName(); // person就可以看作是一個(gè)實(shí)例的引用(reference), 所以可以通過(guò)這個(gè)引用來(lái)調(diào)用Person類中的成員函數(shù)

我們來(lái)總結(jié)一下創(chuàng)建一個(gè)新的類的實(shí)例的整個(gè)流程和步驟:

1. 通過(guò)定義一個(gè)函數(shù)的方式(匿名或者實(shí)名)來(lái)聲明一個(gè)新的類.
2. 如果有必要, 定義這個(gè)新的類的prototype域.
3. 使用new操作符緊跟你所定義的函數(shù)來(lái)創(chuàng)建一個(gè)新的類的實(shí)例. 一旦JavaScript編譯器碰到了new操作符, 它實(shí)際上創(chuàng)建了一個(gè)空的類實(shí)例變量.
4. 將所有這個(gè)類的prototype域中的屬性與方法復(fù)制到這個(gè)新的實(shí)例中, 并將其成員函數(shù)中所有的this指針指向這個(gè)新創(chuàng)建的實(shí)例.
5. 接下來(lái), 執(zhí)行緊跟在new操作符后面的那個(gè)函數(shù).
6. 當(dāng)你執(zhí)行這個(gè)函數(shù)時(shí), 如果你試圖對(duì)一個(gè)不存在的屬性進(jìn)行賦值, JavaScript編譯器將自動(dòng)為你在這個(gè)實(shí)例范圍內(nèi)新創(chuàng)建這個(gè)屬性.
7. 函數(shù)執(zhí)行完畢后, 將這個(gè)初始化完成的實(shí)例返回.

在Prototype中, 使用Class對(duì)象, 你可以以一個(gè)比較簡(jiǎn)單的方式來(lái)聲明一個(gè)新的對(duì)象。通過(guò)使用Class.create(), prototype為你創(chuàng)建了一個(gè)默認(rèn)的構(gòu)造函數(shù)initialize(), 一旦你實(shí)現(xiàn)這一函數(shù), 就可以以一個(gè)類似Java中構(gòu)造函數(shù)的方式來(lái)創(chuàng)建一個(gè)新的類的實(shí)例。

相關(guān)文章

  • THREE.JS入門教程(3)著色器-下

    THREE.JS入門教程(3)著色器-下

    Three.js是一個(gè)偉大的開(kāi)源WebGL庫(kù),WebGL允許JavaScript操作GPU,在瀏覽器端實(shí)現(xiàn)真正意義的3D本文將介紹模擬光照/Attribut變量/更新著色器材質(zhì)/更新著色器材質(zhì)等等感興趣的朋友可以了解下啊
    2013-01-01
  • JS中Object對(duì)象的原型概念基礎(chǔ)

    JS中Object對(duì)象的原型概念基礎(chǔ)

    本篇文章是一篇關(guān)于JS學(xué)習(xí)的基礎(chǔ)內(nèi)容,學(xué)習(xí)Object對(duì)象的原型概念,有興趣的朋友參考下吧。
    2018-01-01
  • JavaScript表達(dá)式:URL 協(xié)議介紹

    JavaScript表達(dá)式:URL 協(xié)議介紹

    javascript:后面可以是表達(dá)式或者使用分號(hào)分隔的表達(dá)式集合如javascript: 5 + 4,感興趣的朋友可以參考下或許可以幫助到你
    2013-03-03
  • 跨域請(qǐng)求的完美解決方法(JSONP, CORS)

    跨域請(qǐng)求的完美解決方法(JSONP, CORS)

    下面小編就為大家?guī)?lái)一篇跨域請(qǐng)求的完美解決方法(JSONP, CORS)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-06-06
  • JavaScript高級(jí)程序設(shè)計(jì)(第3版)學(xué)習(xí)筆記 概述

    JavaScript高級(jí)程序設(shè)計(jì)(第3版)學(xué)習(xí)筆記 概述

    在JavaScript面世之初,沒(méi)有人會(huì)想到它會(huì)被應(yīng)用的如此廣泛,也遠(yuǎn)比一般人想象中的要復(fù)雜強(qiáng)大的多,在我自己學(xué)習(xí)的過(guò)程中,曾經(jīng)有過(guò)多次震撼
    2012-10-10
  • 在JavaScript中操作時(shí)間之getYear()方法的使用教程

    在JavaScript中操作時(shí)間之getYear()方法的使用教程

    這篇文章主要介紹了在JavaScript中操作時(shí)間之getYear()方法的使用教程,是JS入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-06-06
  • javascript 函數(shù)使用說(shuō)明

    javascript 函數(shù)使用說(shuō)明

    其實(shí)通俗的說(shuō)就是一個(gè)有名稱的代碼段,方便重用。
    2010-04-04
  • 從零學(xué)JSON之JSON數(shù)據(jù)結(jié)構(gòu)

    從零學(xué)JSON之JSON數(shù)據(jù)結(jié)構(gòu)

    這篇文章主要介紹了JSON數(shù)據(jù)結(jié)構(gòu)的相關(guān)知識(shí),需要的朋友可以參考下
    2014-05-05
  • javascript Event對(duì)象詳解及使用示例

    javascript Event對(duì)象詳解及使用示例

    Event代表事件狀態(tài),如事件發(fā)生的元素,鍵盤(pán)狀態(tài),鼠標(biāo)位置和鼠標(biāo)按鈕狀態(tài),event對(duì)象只在事件發(fā)生的過(guò)程中才有效,本文整理了一些,喜歡的朋友可以學(xué)習(xí)下
    2013-11-11
  • W3C Group的JavaScript1.8 新特性介紹

    W3C Group的JavaScript1.8 新特性介紹

    在了解了JavaScript1.7的相關(guān)更新后,我們?cè)倮^續(xù)關(guān)注JavaScript1.8的新特性。在W3C Group帶來(lái)的JavaScript系列特性文章中,JavaScript1.8的更新相對(duì)較少!
    2009-05-05

最新評(píng)論