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

js中的面向?qū)ο笾畬?duì)象常見(jiàn)創(chuàng)建方法詳解

 更新時(shí)間:2019年12月16日 10:47:40   作者:dawn-liu  
這篇文章主要介紹了js中的面向?qū)ο笾畬?duì)象常見(jiàn)創(chuàng)建方法,結(jié)合實(shí)例形式較為詳細(xì)的分析了JavaScript創(chuàng)建對(duì)象的四種常用方式,需要的朋友可以參考下

本文實(shí)例講述了js中的面向?qū)ο笾畬?duì)象常見(jiàn)創(chuàng)建方法。分享給大家供大家參考,具體如下:

創(chuàng)建對(duì)象的幾種常用方式

1.使用Object或?qū)ο笞置媪縿?chuàng)建對(duì)象

2.工廠模式創(chuàng)建對(duì)象

3.構(gòu)造函數(shù)模式創(chuàng)建對(duì)象

4.原型模式創(chuàng)建對(duì)象

1.使用Object或?qū)ο笞置媪縿?chuàng)建對(duì)象

使用object

var student = new Object();
student.name = "easy";
student.age = "20";

使用字面量

var sutdent = {
 name : "easy",
 age : 20
};

2.工廠模式創(chuàng)建對(duì)象

function createStudent(name, age) {
 var obj = new Object();
 obj.name = name;
 obj.age = age;
 return obj;
}
var student1 = createStudent("easy1", 20);
var student2 = createStudent("easy2", 20);
...
var studentn = createStudent("easyn", 20);

3.構(gòu)造函數(shù)模式創(chuàng)建對(duì)象

在上面創(chuàng)建Object這樣的原生對(duì)象的時(shí)候,我們就使用過(guò)其構(gòu)造函數(shù)

var obj = new Object();

在創(chuàng)建原生數(shù)組Array類(lèi)型對(duì)象時(shí)也使用過(guò)其構(gòu)造函數(shù):

var arr = new Array(10); //構(gòu)造一個(gè)初始長(zhǎng)度為10的數(shù)組對(duì)象

我們首先了解一下構(gòu)造函數(shù)和普通函數(shù)有什么區(qū)別。

1、實(shí)際上并不存在創(chuàng)建構(gòu)造函數(shù)的特殊語(yǔ)法,其與普通函數(shù)唯一的區(qū)別在于調(diào)用方法。對(duì)于任意函數(shù),使用new操作符調(diào)用,那么它就是構(gòu)造函數(shù);不使用new操作符調(diào)用,那么它就是普通函數(shù)。

2、按照慣例,我們約定構(gòu)造函數(shù)名以大寫(xiě)字母開(kāi)頭,普通函數(shù)以小寫(xiě)字母開(kāi)頭,這樣有利于顯性區(qū)分二者。例如上面的new Array(),new Object()。

3、使用new操作符調(diào)用構(gòu)造函數(shù)時(shí),會(huì)經(jīng)歷(1)創(chuàng)建一個(gè)新對(duì)象;(2)將構(gòu)造函數(shù)作用域賦給新對(duì)象(使this指向該新對(duì)象);(3)執(zhí)行構(gòu)造函數(shù)代碼;(4)返回新對(duì)象;4個(gè)階段。

ok,了解了構(gòu)造函數(shù)和普通函數(shù)的區(qū)別之后,我們使用構(gòu)造函數(shù)將工廠模式的函數(shù)重寫(xiě),并添加一個(gè)方法屬性:

function Student(name, age) {
 this.name = name;
 this.age = age;
 this.alertName = function(){
  alert(this.name)
 };
}
function Fruit(name, color) {
 this.name = name;
 this.color = color;
 this.alertName = function(){
  alert(this.name)
 };
}

這樣我們?cè)俜謩e創(chuàng)建Student和Fruit的對(duì)象

var v1 = new Student("easy", 20);
var v2 = new Fruit("apple", "green");

這時(shí)我們?cè)賮?lái)用instanceof操作符來(lái)檢測(cè)以上對(duì)象類(lèi)型就可以區(qū)分出Student以及Fruit了:

alert(v1 instanceof Student); //true
alert(v2 instanceof Student); //false
alert(v1 instanceof Fruit); //false
alert(v2 instanceof Fruit); //true
alert(v1 instanceof Object); //true 任何對(duì)象均繼承自O(shè)bject
alert(v2 instanceof Object); //true 任何對(duì)象均繼承自O(shè)bject

可以將上面的函數(shù)簡(jiǎn)化:Student和Fruit對(duì)象中共有同樣的方法移到構(gòu)造函數(shù)外部

function Student(name, age) {
 this.name = name;
 this.age = age;
}
function Fruit(name, color) {
 this.name = name;
 this.color = color;
};
function alertName() {
 alert(this.name);
}

我們通過(guò)將alertName()函數(shù)定義為全局函數(shù),這樣對(duì)象中的alertName屬性則被設(shè)置為指向該全局函數(shù)的指針。由此stu1和stu2共享了該全局函數(shù),解決了內(nèi)存浪費(fèi)的問(wèn)題

但是,通過(guò)全局函數(shù)的方式解決對(duì)象內(nèi)部共享的問(wèn)題,終究不像一個(gè)好的解決方法。如果這樣定義的全局函數(shù)多了,我們想要將自定義對(duì)象封裝的初衷便幾乎無(wú)法實(shí)現(xiàn)了。

更好的方案是通過(guò)原型對(duì)象模式來(lái)解決。

4.原型的模式創(chuàng)建對(duì)象

原型鏈甚至原型繼承,是整個(gè)JS中最難的一部分也是最不好理解的一部分,在這里由于我們課程定位的原因,如果對(duì)js有興趣的同學(xué),可以去查閱一下相關(guān)JS原型的一些知識(shí)點(diǎn)。

function Student() {
  this.name = 'easy';
  this.age = 20;
}
Student.prototype.alertName = function(){
  alert(this.name);
};
var stu1 = new Student();
var stu2 = new Student();
stu1.alertName(); //easy
stu2.alertName(); //easy
alert(stu1.alertName == stu2.alertName); //true 二者共享同一函數(shù)

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具http://tools.jb51.net/code/HtmlJsRun測(cè)試上述代碼運(yùn)行效果。

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《javascript面向?qū)ο笕腴T(mén)教程》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)

希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • JS生成登錄驗(yàn)證碼的實(shí)現(xiàn)示例

    JS生成登錄驗(yàn)證碼的實(shí)現(xiàn)示例

    本文主要介紹了JS生成登錄驗(yàn)證碼的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-12-12
  • 原生js添加節(jié)點(diǎn)appendChild、insertBefore方式

    原生js添加節(jié)點(diǎn)appendChild、insertBefore方式

    這篇文章主要介紹了原生js添加節(jié)點(diǎn)appendChild、insertBefore方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • js innerHTML 的一些問(wèn)題的解決方法

    js innerHTML 的一些問(wèn)題的解決方法

    innerHTML 屬性的使用非常流行,因?yàn)樗峁┝撕?jiǎn)單的方法完全替代一個(gè) HTML 元素的內(nèi)容。另外一個(gè)方法是使用 DOM Level 2 API(removeChild, createElement, appendChild)。但很顯然,使用 innerHTML 修改 DOM tree 是非常容易且有效的方法。
    2008-06-06
  • 理解javascript正則表達(dá)式

    理解javascript正則表達(dá)式

    這篇文章主要為大家詳細(xì)介紹了javascript正則表達(dá)式,由淺入深的幫助大家學(xué)習(xí)正則表達(dá)式,感興趣的小伙伴們可以參考一下
    2016-03-03
  • javascript面向?qū)ο蟪绦蛟O(shè)計(jì)實(shí)踐常用知識(shí)點(diǎn)總結(jié)

    javascript面向?qū)ο蟪绦蛟O(shè)計(jì)實(shí)踐常用知識(shí)點(diǎn)總結(jié)

    這篇文章主要介紹了javascript面向?qū)ο蟪绦蛟O(shè)計(jì)實(shí)踐常用知識(shí)點(diǎn),結(jié)合實(shí)例形式總結(jié)分析了javascript面向?qū)ο蟪绦蛟O(shè)計(jì)中原型引用類(lèi)型、屬性、方法相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下
    2019-07-07
  • JavaScript設(shè)置彈出式獨(dú)立窗口頁(yè)面和window的方法舉例詳解

    JavaScript設(shè)置彈出式獨(dú)立窗口頁(yè)面和window的方法舉例詳解

    window.open是網(wǎng)頁(yè)中經(jīng)常遇到的彈出窗口代碼,不是網(wǎng)絡(luò)中比較反感的那類(lèi)彈出代碼,下面這篇文章主要給大家介紹了關(guān)于JavaScript設(shè)置彈出式獨(dú)立窗口頁(yè)面和window的方法,需要的朋友可以參考下
    2024-01-01
  • 收集json解析的四種方法分享

    收集json解析的四種方法分享

    這篇文章主要介紹了json解析的四種方法,有需要的朋友可以參考一下
    2014-01-01
  • js實(shí)現(xiàn)樹(shù)形數(shù)據(jù)轉(zhuǎn)成扁平數(shù)據(jù)的方法示例

    js實(shí)現(xiàn)樹(shù)形數(shù)據(jù)轉(zhuǎn)成扁平數(shù)據(jù)的方法示例

    這篇文章主要介紹了js實(shí)現(xiàn)樹(shù)形數(shù)據(jù)轉(zhuǎn)成扁平數(shù)據(jù)的方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • JS錨點(diǎn)的設(shè)置與使用方法

    JS錨點(diǎn)的設(shè)置與使用方法

    這篇文章主要介紹了JS錨點(diǎn)的設(shè)置與使用方法,涉及javascript針對(duì)頁(yè)面元素屬性的簡(jiǎn)單動(dòng)態(tài)操作技巧,需要的朋友可以參考下
    2016-09-09
  • 詳解JavaScript前端加解密工具庫(kù)的使用

    詳解JavaScript前端加解密工具庫(kù)的使用

    這篇文章主要為大家詳細(xì)介紹了JavaScript前端加解密工具庫(kù)(CryptoJS、JSEncrypt、bcryptjs)的具體使用,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解下
    2023-12-12

最新評(píng)論