關于Js中new操作符的作用詳解
前言
Js是當今時代最常用的代碼操作語言,其中new操作符尤為常見。對于很多代碼小白來說,并不清楚new在Js中扮演著怎樣的角色,具體是做什么用,干了什么。本文從new操作符的作用著手,簡單介紹new操作符相關知識。
什么是new?
眾所周知,在JS中,new的作用是通過構(gòu)造函數(shù)來創(chuàng)建一個實例對象。
像下面這樣:(和普通函數(shù)不一樣,當函數(shù)用作構(gòu)造函數(shù)時,首字母一般要大寫,以作區(qū)分。)
function Foo(name) { this.name = name; } console.log("new Foo('mm')的類型:",typeof new Foo('mm')); // object console.log("Foo的類型:",typeof Foo); // function
創(chuàng)建了一個空對象
var obj=new Object();
在Js代碼中,new操作符的主要作用是產(chǎn)生對象。通過new創(chuàng)建空對象,為創(chuàng)建對象打基底。
設置原型鏈
obj.__proto__= Func.prototype;
JS中在利用new操作符建好基底后,就開始下一步的Js代碼操作,設置原型鏈。new通過構(gòu)造函數(shù)創(chuàng)建出的實例可以訪問到構(gòu)造函數(shù)原型鏈中的屬性,換言之,通過new操作符,原型鏈鏈接了實例和構(gòu)建函數(shù)。
(改變this指向)讓Func中的this指向obj,并執(zhí)行Func的函數(shù)體。
var result =Func.call(obj);
一般情況下,在Js代碼組中,出現(xiàn)this時,構(gòu)造函數(shù)內(nèi)部是正常工作,但當通過new操作符改變this指向后,所出現(xiàn)的返回值會被正常的返回出去。
判斷Func的返回值類型:如果是值類型,返回obj。如果是引用類型,就返回這個引用類型的對象。
if (typeof(result) == "object"){ func=result; } else{ func=obj; }
從上述一組new操作符代碼中可看出,new還可用來判斷Func的返回值類型。如果返回值是值類型,則正常返回。如果是引用類型,就返回到引用類型的對象。
以上四點是new操作符在Js代碼中的主要作用,對于Js代碼小白希望可以有幫助。
總結(jié)
到此這篇關于關于Js中new操作符作用的文章就介紹到這了,更多相關Js new操作符作用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
基于JavaScript 數(shù)據(jù)類型之Boolean類型分析介紹
本篇文章小編為大家介紹,基于JavaScript 數(shù)據(jù)類型之Boolean類型分析介紹。需要的朋友參考下2013-04-04深入理解JavaScript系列(19):求值策略(Evaluation strategy)詳解
這篇文章主要介紹了深入理解JavaScript系列(19):求值策略(Evaluation strategy)詳解,本文講解了一般理論、按值傳遞、按引用傳遞、按共享傳遞(Call by sharing)、按共享傳遞是按值傳遞的特例等內(nèi)容,需要的朋友可以參考下2015-03-03JavaScript高級程序設計(第3版)學習筆記3 js簡單數(shù)據(jù)類型
數(shù)據(jù)類型是編程語言的磚瓦,是所有你能想象到的復雜抽象的基礎,在現(xiàn)代編程語言中,除了語言本身內(nèi)置的一些簡單數(shù)據(jù)類型外,基本上都提供了用于自定義數(shù)據(jù)類型的語言機制(在C中也可以利用結(jié)構(gòu)體來實現(xiàn)),這些機制在一定程度上也決定了該語言的流行度和生命力2012-10-10