摘要:原文鏈接一什么是非構造函數的繼承比如,現在有一個對象,叫做中國人。通過函數,繼承了。中國北京上海香港廈門北京上海香港廈門北京上海香港這時,父對象就不會受到影響了。目前,庫使用的就是這種繼承方法。
原文鏈接
一、什么是"非構造函數"的繼承?比如,現在有一個對象,叫做"中國人"。
var Chinese = { nation: "中國" }
還有一個對象,叫做"醫生"。
var Doctor = { career: "醫生" }
請問怎樣才能讓"醫生"去繼承"中國人",也就是說,我怎樣才能生成一個"中國醫生"的對象?
這里要注意,這兩個對象都是普通對象,不是構造函數,無法使用構造函數方法實現"繼承"。
二、object()方法json格式的發明人Douglas Crockford,提出了一個object()函數,可以做到這一點。
function object(o) { function F() {} F.prototype = o; return new F(); } var Doctor = object(Chinese) Doctor.career = "醫生" console.log(Doctor.nation) // "中國"
這個object()函數,其實只做一件事,就是把子對象的prototype屬性,指向父對象,從而使得子對象與父對象連在一起。
三、淺拷貝除了使用原型鏈以外,還有另一種思路:把父對象的屬性,全部拷貝給子對象,也能實現繼承。
下面這個函數,就是在做拷貝:
function extendCopy(p) { var c = {}; for(var i in p) { c[i] = p[i] } return c; } var Doctor = extendCopy(Chinese) Doctor.career = "醫生" console.log(Doctor.nation) // "中國"
但是,這樣的拷貝有一個問題。那就是,如果父對象的屬性等于數組或另一個對象,那么實際上,子對象獲得的只是一個內存地址,而不是真正拷貝,因此存在父對象被篡改的可能。
現在給Chinese添加一個"出生地"屬性,它的值是一個數組。
通過extendCopy()函數,Doctor繼承了Chinese。
然后,我們為Doctor的"出生地"添加一個城市。
我們會發現Chinese的"出生地"也被改掉了。
Chinese.birthPlaces = ["北京","上海","香港"]; var Doctor = extendCopy(Chinese); Doctor.birthPlaces.push("廈門"); alert(Doctor.birthPlaces); //北京, 上海, 香港, 廈門 alert(Chinese.birthPlaces); //北京, 上海, 香港, 廈門
所以,extendCopy()只是拷貝基本類型的數據,我們把這種拷貝叫做"淺拷貝"。這是早期jQuery實現繼承的方式。
四、深拷貝所謂"深拷貝",就是能夠實現真正意義上的數組和對象的拷貝。它的實現并不難,只要遞歸調用"淺拷貝"就行了。
var Chinese = { nation: "中國" } Chinese.birthPlaces = ["北京","上海","香港"]; function deepCopy(p, c) { var c = c || {}; for(var i in p) { if (typeof p[i] === "object") { c[i] = (p[i].constructor === Array) ? [] : {}; deepCopy(p[i], c[i]); } else { c[i] = p[i]; } } return c; } var Doctor = deepCopy(Chinese); Doctor.birthPlaces.push("廈門"); console.log(Doctor.birthPlaces); // ["北京", "上海", "香港", "廈門"] console.log(Chinese.birthPlaces); // ["北京", "上海", "香港"]
這時,父對象就不會受到影響了。
目前,jQuery庫使用的就是這種繼承方法。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/81839.html
摘要:很多情況下,通常一個人類,即創建了一個具體的對象。對象就是數據,對象本身不包含方法。類是相似對象的描述,稱為類的定義,是該類對象的藍圖或原型。在中,對象通過對類的實體化形成的對象。一類的對象抽取出來。注意中,對象一定是通過類的實例化來的。 showImg(https://segmentfault.com/img/bVTJ3H?w=900&h=385); 馬上就要到七夕了,離年底老媽老爸...
摘要:很多情況下,通常一個人類,即創建了一個具體的對象。對象就是數據,對象本身不包含方法。類是相似對象的描述,稱為類的定義,是該類對象的藍圖或原型。在中,對象通過對類的實體化形成的對象。一類的對象抽取出來。注意中,對象一定是通過類的實例化來的。 showImg(https://segmentfault.com/img/bVTJ3H?w=900&h=385); 馬上就要到七夕了,離年底老媽老爸...
摘要:很多情況下,通常一個人類,即創建了一個具體的對象。對象就是數據,對象本身不包含方法。類是相似對象的描述,稱為類的定義,是該類對象的藍圖或原型。在中,對象通過對類的實體化形成的對象。一類的對象抽取出來。注意中,對象一定是通過類的實例化來的。 showImg(https://segmentfault.com/img/bVTJ3H?w=900&h=385); 馬上就要到七夕了,離年底老媽老爸...
摘要:對象重新認識面向對象面向對象從設計模式上看,對象是計算機抽象現實世界的一種方式。除了字面式聲明方式之外,允許通過構造器創建對象。每個構造器實際上是一個函數對象該函數對象含有一個屬性用于實現基于原型的繼承和共享屬性。 title: JS對象(1)重新認識面向對象 date: 2016-10-05 tags: JavaScript 0x00 面向對象 從設計模式上看,對象是...
摘要:子類不是父類實例的問題是由類式繼承引起的。所以寄生式繼承和構造函數繼承的組合又稱為一種新的繼承方式。但是這里的寄生式繼承處理的不是對象,而是類的原型。看上去略微復雜,還得好好研究。 寄生組合式繼承(終極繼承者) 前面學習了類式繼承和構造函數繼承組合使用,也就是組合繼承,但是這種繼承方式有個問題,就是子類不是父類的實例,而子類的原型是父類的實例。子類不是父類實例的問題是由類式繼承引起的。...
閱讀 813·2021-11-18 10:02
閱讀 2503·2021-11-11 16:54
閱讀 2750·2021-09-02 09:45
閱讀 654·2019-08-30 12:52
閱讀 2774·2019-08-29 14:04
閱讀 2745·2019-08-29 12:39
閱讀 448·2019-08-29 12:27
閱讀 1887·2019-08-26 13:23