摘要:原型在中函數(shù)是一個(gè)包含屬性和方法的類型的對象原型就是類型對象的一個(gè)屬性每個(gè)函數(shù)都有一個(gè)屬性它默認(rèn)指向一個(gè)空對象即原型對象原型對象中有一個(gè)屬性它指向函數(shù)對象原型是用于保存對象的共享屬性和方法的原型的屬性和方法并不會(huì)影響函數(shù)本身的屬性和方
原型
在JS中 函數(shù)是一個(gè)包含屬性和方法的Function類型的對象 原型prototype就是Function類型對象的一個(gè)屬性
每個(gè)函數(shù)都有一個(gè)prototype屬性, 它默認(rèn)指向一個(gè)Object空對象---即:原型對象
原型對象中有一個(gè)屬性constructor, 它指向函數(shù)對象
原型是用于保存對象的共享屬性和方法的 原型的屬性和方法并不會(huì)影響函數(shù)本身的屬性和方法
function fn(){ return "hello" } console.log(typeof fn.prototype) //object獲取原型
通過構(gòu)造函數(shù)的prototype屬性
function fn(){ console.log("this is a function") } console.log(fn.prototype); //{constructor: ?}
通過Object對象的getgetPrototypeOf()方法
function fn(){ console.log("this is a function") } console.log(Object.getPrototypeOf(fn)); //? () { [native code] }原型的屬性和方法
原型的屬性和方法多帶帶進(jìn)行定義
構(gòu)造函數(shù).prototype.屬性名 = 屬性值 構(gòu)造函數(shù).prototype.方法名 = function(){ }
直接為原型定義一個(gè)新對象
構(gòu)造函數(shù).prototype = { 屬性名:屬性值, 方法:function(){} }自有屬性與原型屬性
自有屬性:通過對象的引用添加的屬性
原型屬性:從原型對象中繼承而來 如果原型對象中屬性值改變 則所有繼承
自該原型的對象屬性都改變
function Person(name){ //構(gòu)造函數(shù)本身的屬性 --> 自有屬性 this.name = name; } //通過構(gòu)造函數(shù)Person的prototype新增屬性 --> 原型屬性 Person.prototype.age=29 var man=new Person("林更新"); console.log(man.name); //林更新 console.log(man.age) //29 var woman=new Person("宋佳"); woman.age=38; console.log(woman.name) //宋佳 console.log(woman.age) //38 Person.prototype.age=18; console.log(man.age) //18 console.log(woman.age) //38檢測自有 原型屬性
使用hasOwnProperty()方法檢測對象是否具有指定的自有屬性
function Person() { } var man =new Person() console.log(man.hasOwnProperty("name")) //false
使用in關(guān)鍵字檢測對象及其原型鏈中是否具有指定屬性
function Person() { } var man =new Person() console.log("name" in man) //false顯示原型對象和隱式原型對象
每個(gè)函數(shù)function都有一個(gè)prototype,即顯式原型
每個(gè)實(shí)例對象都有一個(gè)__proto__,可稱為隱式原型
對象的隱式原型的值為其對應(yīng)構(gòu)造函數(shù)的顯式原型的值
函數(shù)的prototype屬性: 在定義函數(shù)時(shí)自動(dòng)添加的, 默認(rèn)值是一個(gè)空Object對象
對象的__proto__屬性: 創(chuàng)建對象時(shí)自動(dòng)添加的, 默認(rèn)值為構(gòu)造函數(shù)的prototype屬性值
我們能直接操作顯式原型, 但不能直接操作隱式原型(ES6之前)
function Person() { this.name="MasterYi" } Person.prototype.age=100; var man=new Person; console.log(man.prototype); // undefined 表示對象中不存在該屬性 console.log(man.__proto__); // {age: 100, constructor: ?}原型鏈
訪問一個(gè)對象的屬性時(shí),先在自身屬性中查找,找到返回
如果沒有, 再沿著__proto__這條鏈向上查找, 找到返回
如果最終沒找到, 返回undefined
__proto__這條原型查找鏈就是原型鏈: 隱式原型鏈
讀取對象的屬性值時(shí): 會(huì)自動(dòng)到原型鏈中查找
設(shè)置對象的屬性值時(shí): 不會(huì)查找原型鏈, 如果當(dāng)前對象中沒有此屬性, 直接添加此屬性并設(shè)置其值
方法一般定義在原型中, 屬性一般通過構(gòu)造函數(shù)定義在對象本身上
作用:用來查找對象的屬性(方法)
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/108260.html
摘要:因?yàn)檫@造成了繼承鏈的紊亂,因?yàn)榈膶?shí)例是由構(gòu)造函數(shù)創(chuàng)建的,現(xiàn)在其屬性卻指向了為了避免這一現(xiàn)象,就必須在替換對象之后,為新的對象加上屬性,使其指向原來的構(gòu)造函數(shù)。這個(gè)函數(shù)接收兩個(gè)參數(shù)子類型構(gòu)造函數(shù)和超類型構(gòu)造函數(shù)。 最近一直在研究js面向?qū)ο?,原型鏈繼承是一個(gè)難點(diǎn),下面是我對繼承的理解以下文章借鑒自CSDN季詩筱的博客 原型鏈繼承的基本概念: ES中描述了原型鏈的概念,并將原型鏈作為實(shí)現(xiàn)...
摘要:寄生組合式繼承的繼承方式有多種主要有原型鏈繼承借用構(gòu)造函數(shù)組合式繼承寄生式繼承和寄生組合式繼承。中利用定義類,實(shí)現(xiàn)類的繼承子類里調(diào)用父類構(gòu)造函數(shù)實(shí)現(xiàn)實(shí)例屬性和方法的繼承子類原型繼承父類原型,實(shí)現(xiàn)原型對象上方法的繼承。 JavaScript中實(shí)現(xiàn)繼承 ??在JavaScript中實(shí)現(xiàn)繼承主要實(shí)現(xiàn)以下兩方面的屬性和方法的繼承,這兩方面相互互補(bǔ),既有共享的屬性和方法,又有特有的屬性和方法。 ...
摘要:繼承簡介在的中的面向?qū)ο缶幊蹋^承是給構(gòu)造函數(shù)之間建立關(guān)系非常重要的方式,根據(jù)原型鏈的特點(diǎn),其實(shí)繼承就是更改原本默認(rèn)的原型鏈,形成新的原型鏈的過程。 showImg(https://segmentfault.com/img/remote/1460000018998684); 閱讀原文 前言 JavaScript 原本不是純粹的 OOP 語言,因?yàn)樵?ES5 規(guī)范中沒有類的概念,在 ...
摘要:創(chuàng)建自定義的構(gòu)造函數(shù)之后,其原型對象只會(huì)取得屬性,其他方法都是從繼承來的。優(yōu)缺點(diǎn)寄生式繼承在主要考慮對象而不是創(chuàng)建自定義類型和構(gòu)造函數(shù)時(shí),是十分有用的。 原文鏈接:https://kongchenglc.coding.me... 1.原型鏈 ??js的繼承機(jī)制不同于傳統(tǒng)的面向?qū)ο笳Z言,采用原型鏈實(shí)現(xiàn)繼承,基本思想是利用原型讓一個(gè)引用類型繼承另一個(gè)引用類型的屬性和方法。理解原型鏈必須先理...
摘要:可以通過構(gòu)造函數(shù)和原型的方式模擬實(shí)現(xiàn)類的功能。原型式繼承與類式繼承類式繼承是在子類型構(gòu)造函數(shù)的內(nèi)部調(diào)用超類型的構(gòu)造函數(shù)。寄生式繼承這種繼承方式是把原型式工廠模式結(jié)合起來,目的是為了封裝創(chuàng)建的過程。 js繼承的概念 js里常用的如下兩種繼承方式: 原型鏈繼承(對象間的繼承) 類式繼承(構(gòu)造函數(shù)間的繼承) 由于js不像java那樣是真正面向?qū)ο蟮恼Z言,js是基于對象的,它沒有類的概念。...
閱讀 1277·2021-10-14 09:50
閱讀 1578·2019-08-30 15:54
閱讀 1040·2019-08-30 11:22
閱讀 2929·2019-08-30 10:50
閱讀 1815·2019-08-29 18:39
閱讀 3063·2019-08-29 13:07
閱讀 2086·2019-08-28 17:54
閱讀 760·2019-08-26 17:44