国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

javascript教程之不完整的繼承(js原型鏈)

2024-05-06 15:58:51
字體:
來源:轉載
供稿:網友
Javascript的繼承和標準的oop繼承有很大的區別,Javascript的繼承是采用原型鏈的技術,下面使用示例學習一下JS的繼承

Javascript的繼承和標準的oop繼承有很大的區別,Javascript的繼承是采用原型鏈的技術,每個類都會將“成員變量”和“成員函數”放到 prototype 上,Js++都過superclass將其鏈接起來,即 C.prototype.superclass = C.superclass = P.prototype;
當 var c = new C()時,c.__proto__ = C.prototype ;
當 c訪問“成員變量”時,如果在__proto__無法獲取時,就會到C.prototype查找,如果又不存在,又會到父類的prototype查找,由于只有 __proto__ 是對象創建時分配的(每個對象獨立分配),其他都是定義時分配的(每個對象共享),此時,如果訪問C.prototype中“成員變量”是對象時,不修改“成員變量”的本身,而是修改“成員變量”對象的成員時,修改的“成員變量”對象的成員就會被所有對象實例共享,這樣就違背類設計的初衷。
例如:

復制代碼 代碼如下:


'package'.j(function () {
        'class A'.j(function () {
            jpublic({
                v:{a: 1}
            });
            jprivate({
                p:{a:1}
            });
            jprotected({
                x:{a:1}
            });

        });

        'class B extends A'.j(function () {

        });
});

var b1 = new B();
b1.v.a = 5;
b1.x.a = 5;
var b2 = new B();

console.log(b1.v.a) // 輸出為 5
console.log(b1.x.a) // 輸出為 5

console.log(b2.v.a) // 輸出也為 5,并不是預想的 1
console.log(b2.x.a) // 輸出為 1
console.log(b2.p.a) // 不可用,會提示 p不存在

如何解決此問題?
A. 將 v 這樣的成員“成員變量”(其本身是對象)不在原型鏈上定義,而是在構造函數中調用,此時,創建對象實例時,就會在對象的__proto__上分配。

Js++提供了類似的方法,只要在jprivate中定義的“成員變量”或“成員函數”都會分配到對象的__proto__上,且只有本實例可用, jprotected中定義的“成員變量”(其本身是對象)也會分配到對象的__proto__上,且只有繼承他的可用,

B. 原型鏈上只定義只讀的“成員變量”(其本身是對象)

C.jpublic 定義的“成員變量”(其本身是對象)中的成員,只是只讀成員,切記不可賦值,否則會在各個實例中共享。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 车险| 邵武市| 开封县| 安泽县| 资溪县| 宜都市| 漳州市| 石景山区| 黎平县| 苏尼特右旗| 保山市| 油尖旺区| 沧州市| 牙克石市| 普定县| 文昌市| 青阳县| 武强县| 阳原县| 阿瓦提县| 屏山县| 阳新县| 桃源县| 寿阳县| 新兴县| 涿州市| 东兰县| 霸州市| 大名县| 仙桃市| 都匀市| 惠东县| 连平县| 赤水市| 吉木萨尔县| 娱乐| 广东省| 吐鲁番市| 晋江市| 乌鲁木齐市| 江孜县|