淺談javascript中new操作符的原理
javascript中的new是一個(gè)語(yǔ)法糖,對(duì)于學(xué)過(guò)c++,java 和c#等面向?qū)ο笳Z(yǔ)言的人來(lái)說(shuō),以為js里面是有類(lèi)和對(duì)象的區(qū)別的,實(shí)現(xiàn)上js并沒(méi)有類(lèi),一切皆對(duì)象,比java還來(lái)的徹底
new的過(guò)程實(shí)際上是創(chuàng)建一個(gè)新對(duì)象,把新象的原型設(shè)置為構(gòu)造器函數(shù)的原型,在使用new的過(guò)程中,一共有3個(gè)對(duì)象參與了協(xié)作,構(gòu)造器函數(shù)是第一個(gè)對(duì)象,原型對(duì)象是二個(gè),新生成了一個(gè)空對(duì)象是第三個(gè)對(duì)象,最終返回的是一個(gè)空對(duì)象,但這個(gè)空對(duì)象不是真空的,而是已經(jīng)含有原型的引用(__proto__)
步驟如下:
(1) 創(chuàng)建一個(gè)空對(duì)象obj
(2) 讓空對(duì)象的__proto__(IE沒(méi)有該屬性)成員指向了構(gòu)造函數(shù)的prototype成員對(duì)象
(3) 使用apply調(diào)用構(gòu)造器函數(shù),this綁定到空對(duì)象obj上。
(4) 返回空對(duì)象obj
可以自己寫(xiě)個(gè)函數(shù)替代使用new也是完全可以的,示例代碼如下:
function NEW_OBJECT(Foo){ var obj={}; obj.__proto__=Foo.prototype; obj.__proto__.constructor=Foo; Foo.apply(obj,arguments) return obj; }
以上這篇淺談javascript中new操作符的原理就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript中Function()函數(shù)的使用教程
這篇文章主要介紹了JavaScipt中Function()函數(shù)的使用教程,是JavaScipt入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-06-06關(guān)于session和cookie的簡(jiǎn)單理解
下面小編就為大家?guī)?lái)一篇關(guān)于session和cookie的簡(jiǎn)單理解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-06-06JavaScript中constructor()方法的使用簡(jiǎn)介
這篇文章主要介紹了JavaScript中constructor()方法的使用簡(jiǎn)介,是JS入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-06-06Javascript標(biāo)準(zhǔn)DOM Range操作全集
Javascript標(biāo)準(zhǔn)DOM Range操作全集...2007-01-01Google Dart編程語(yǔ)法和基本類(lèi)型學(xué)習(xí)教程
Dart編程語(yǔ)言是一個(gè)完全面向?qū)ο蟮恼Z(yǔ)言,包括基礎(chǔ)類(lèi)型如int變量也都是對(duì)象,本文主要介紹了Google Dart編程語(yǔ)法和基本類(lèi)型2013-11-11JavaScript高級(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