您好,登錄后才能下訂單哦!
這篇“javascript的構(gòu)造函數(shù), 原型,原型鏈和new是什么”文章的知識點大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“javascript的構(gòu)造函數(shù), 原型,原型鏈和new是什么”文章吧。
如果一個函數(shù)被設(shè)計出來,是用于通過new關(guān)鍵字創(chuàng)建對象的,它就是一個構(gòu)造函數(shù)。
如下:
function Father(name,age){this.name = name;this.age = age;}function Father(name,age){ this.name = name; this.age = age; }
構(gòu)造函數(shù)有如下特征:
(1)、首字母大寫
(2)、構(gòu)造函數(shù)應(yīng)該使用new來調(diào)用
(3)、構(gòu)造函數(shù)調(diào)用后,會返回一個對象
(4)、構(gòu)造函數(shù)的返回值
若返回的值是一個數(shù)字、字符串、布爾,直接忽略,就當(dāng)看不見。
若返回的值是一個對象,則使用返回的對象
(5)、構(gòu)造函數(shù)中的this
當(dāng)你在構(gòu)造函數(shù)中使用this,它指代的是被新建的對象
通過new,該過程也叫做實例化,如下:
const let = new Father('jhony',34);
內(nèi)存中創(chuàng)建一個新的對象{}將新對象的_proto_(chorme已經(jīng)改為了[[Prototype]])指向構(gòu)造函數(shù)的prototype將this綁定到新對象上fn.apply(obj,this)給新對象添加屬性如果構(gòu)造函數(shù)返回非空對象,則返回該對象;否則,返回剛創(chuàng)建的新對象
[[prototype]]屬性是隱藏的,不過目前大部分新瀏覽器實現(xiàn)方式是使用__proto__來表示。構(gòu)造函數(shù)的prototype 屬性我們是可以顯式訪問的。
Father.prototype
就是原型,它是一個對象,我們也稱它為原型對象。
原型可以共享方法,原型中的this指向?qū)嵗?/p>
例如Father.protoype.getAge
可以共享一個方法,不會開辟獨立的空間
Object.prototype
的隱式原型,即Object.prototype._proto_
最終指向null
幾條公式:
Object.__proto__ === Function.prototype; Function.prototype.__proto__ === Object.prototype; Object.prototype.__proto__ === null;
對象可以根據(jù)__proto__屬性去尋找方法,直到找到了或者找到頂層為止,這個找的過程所依賴的__proto__就叫做原型鏈(噗- - 自己的口水話翻譯)
類是一種語法糖,構(gòu)造函數(shù)的另一種寫法而已
以上就是關(guān)于“javascript的構(gòu)造函數(shù), 原型,原型鏈和new是什么”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對大家有幫助,若想了解更多相關(guān)的知識內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。