欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

Javascript中對(duì)象和繼承的關(guān)系是什么

這篇文章給大家介紹Javascript中對(duì)象和繼承的關(guān)系是什么,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。

成都創(chuàng)新互聯(lián)公司主要從事成都網(wǎng)站制作、網(wǎng)站建設(shè)、外貿(mào)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)恭城,十載網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來(lái)電咨詢建站服務(wù):13518219792

Javascript是一門(mén)函數(shù)式編程語(yǔ)言,Javascript當(dāng)中函數(shù)是核心,在Javascript中函數(shù)也是對(duì)象,函數(shù)對(duì)象在創(chuàng)建的時(shí)候會(huì)被添加屬性和方法。

在Javascript中函數(shù)對(duì)象有兩種調(diào)用方式,一種是new關(guān)鍵字的調(diào)用,另一種是沒(méi)有new關(guān)鍵字的調(diào)用,前者會(huì)返回一個(gè)對(duì)象,后者會(huì)返回return語(yǔ)句中的內(nèi)容。

function Obj (name) {
 this.name = name;
 return name;
}

用new關(guān)鍵字來(lái)調(diào)用如下:

var obj = new Obj('張三') // 返回 { 'name': '張三' }

不用new關(guān)鍵字調(diào)用如下:

var obj = Obj('張三') // 返回 '張三'

說(shuō)完了js當(dāng)中的對(duì)象和調(diào)用方式,那讓我們來(lái)理解下什么是對(duì)象。

什么是對(duì)象?

對(duì)象是類的一個(gè)實(shí)例(對(duì)象可不是女朋友),有狀態(tài)和行為。例如:一個(gè)電腦就是一個(gè)對(duì)象,它的狀態(tài)有:大小、顏色、品牌等,他的行為有:播視頻、聽(tīng)音樂(lè)、聊天等。

而類是對(duì)象的抽象,可以理解為類是一個(gè)模板,它來(lái)描述一類對(duì)象的狀態(tài)和行為。軟件對(duì)象也有狀態(tài)和行為,軟件對(duì)象的狀態(tài)就是屬性,行為就是方法。在軟件開(kāi)發(fā)中,在方法中可以操作對(duì)象的內(nèi)部狀態(tài),對(duì)象的相互調(diào)用也是通過(guò)方法來(lái)完成。

類既然可以理解為一個(gè)模板,我們通過(guò)一個(gè)Person的簡(jiǎn)單例子來(lái)理解下:

function Person (name, age, sex) {
 this.name = name;
 this.age = age;
 this.sex = sex;
 run = function () {
 console.log('Run')
 }
}

 在這個(gè)類中name,age,sex為這個(gè)類的屬性,而run為這個(gè)類的方法;Person的職責(zé)是構(gòu)造對(duì)象,進(jìn)行對(duì)象的初始化。

接下來(lái)我們看下在js中如何聲明并調(diào)用對(duì)象。

對(duì)象的創(chuàng)建(多種方法)

塊級(jí)對(duì)象

var person = {
 name: '王小端coder',
 age: 29
}
console.log(person.name); // 王小端coder

構(gòu)造函數(shù) --- 系統(tǒng)自帶

var obj = new Object();
obj.name = '王小端coder'

console.log(obj.name); // 王小端coder

系統(tǒng)自帶的對(duì)象有:Object、Array、Number、Boolean、Date等

構(gòu)造函數(shù) --- 自定義

function Obj (name) {
 this.name = name;
}
var obj = new Obj('王小端coder');
console.log(obj.name); // 王小端coder

對(duì)象的增刪改查

增:為對(duì)象添加一個(gè)屬性

var person = {};
person.name = '王小端coder';
console.log(person.name);

刪:通過(guò)delete操作符刪除一個(gè)對(duì)象的屬性

var person = {
 name: '王小端coder'
};
console.log(person.name); // 王小端coder
delete person.name;
console.log(person.name); // undefined

改:直接通過(guò)賦值來(lái)修改一個(gè)對(duì)象的屬性

var person = {
 name: '王小端coder'
};
console.log(person.name); // 王小端coder
person.name = '王小端JS'
console.log(person.name); // 王小端JS

查:查詢對(duì)象的屬性,有兩種方法

var person = {
 name: '王小端coder'
};
console.log(person['name']); // 第一種方法
console.log(person.name); // 第二種方法

原型的定義

原型是function對(duì)象的一個(gè)屬性,它定義了構(gòu)造函數(shù)制造出的對(duì)象的公共祖先。通過(guò)構(gòu)造函數(shù)產(chǎn)生的對(duì)象,可以繼承該原型的屬性和方法,原型也是對(duì)象。

function Person (name, age) {
 this.name = name;
 this.age = age;
}

Person.prototype = {
 eat: function (food) {
 console.log('eat ' + food);
 },
 sleep: function () {
 console.log('sleeping');
 }
}
var person = new Person ('王小端coder', 29);
console.log(person.name); // 王小端coder
person.eat('apple') // eat apple

我們定義了一個(gè)Person構(gòu)造函數(shù),而屬于Person構(gòu)造對(duì)象共有的方法,則定義到了Person原型上。

查看構(gòu)造函數(shù)原型的接口:隱士屬性__proto__(其實(shí)我們能夠訪問(wèn)原型的屬性,或者說(shuō)繼承原型,靠的就是__proto__屬性連接著構(gòu)造函數(shù)和原型,可以說(shuō)沒(méi)有__proto__屬性的存在,就無(wú)法實(shí)現(xiàn)原型的繼承)直接通過(guò)new操作符創(chuàng)建的對(duì)象訪問(wèn)__proto__屬性即可查看到原型。

原型鏈

原型鏈就是將一個(gè)個(gè)原型串聯(lián)起來(lái),形成一條原型繼承的鏈子。Child繼承Parent, Parent繼承GrandParent, 而GrandParent沒(méi)有自定義原型,所以默認(rèn)為原型鏈的最頂端new Object();

對(duì)象的繼承(多種方式)

創(chuàng)建的子類將繼承超類的所有屬性和方法,包括構(gòu)造函數(shù)及方法的實(shí)現(xiàn)。記住,所有屬性和方法都是公用的,因此子類可直接訪問(wèn)這些方法。子類還可添加超類中沒(méi)有的新屬性和方法,也可以覆蓋超類的屬性和方法。和其他功能一樣,JavaScript實(shí)現(xiàn)繼承的方式不止一種。這是因?yàn)镴avaScript中的繼承機(jī)制并不是明確規(guī)定的,而是通過(guò)模仿實(shí)現(xiàn)的。這意味著所有的繼承細(xì)節(jié)并非完全由解釋程序處理。作為開(kāi)發(fā)者,你有權(quán)決定最適用的繼承方式。

我們先定義一個(gè)父類

// 定義一個(gè)父類
function Person (name) {
 this.name = name;
 this.sleep = function () {
 console.log('朕正在睡覺(jué)!');
 }
}
// 在父類原型上面增加一個(gè)方法
Person.prototype.eat = function (food) {
 console.log('朕現(xiàn)在吃的食物是:' + food);
}

下面為您介紹幾種具體的繼承方式:

原型鏈繼承

// 定義一個(gè)嬰兒來(lái)繼承人的父類
function Baby () {
}
Baby.prototype = new Person();
Baby.prototype.name = '小端';

var baby = new Baby()
console.log(baby.name); // 小端
baby.eat('milk'); // 朕現(xiàn)在吃的食物是:milk

優(yōu)點(diǎn): 簡(jiǎn)單、易于實(shí)現(xiàn);父類新增的原型方法和屬性子類都能訪問(wèn)到;

缺點(diǎn): 無(wú)法實(shí)現(xiàn)多繼承;來(lái)自原型的對(duì)象的所有屬性被所有實(shí)例共享;如果為子類增加屬性和方法,無(wú)法放倒構(gòu)造器中;創(chuàng)建子類實(shí)例時(shí)無(wú)法向父類構(gòu)造函數(shù)傳參;

構(gòu)造繼承

// 定義一個(gè)嬰兒來(lái)繼承人的父類
function Baby (name) {
 Person.call(this);
 this.name = name || 'Coder'
}

let baby = new Baby();
console.log(baby.name); // Coder
baby.sleep(); // 朕正在睡覺(jué)!
console.log(baby instanceof Person); // false
console.log(baby instanceof Baby); // true

優(yōu)點(diǎn): 可以實(shí)現(xiàn)多繼承;創(chuàng)建子類時(shí)可以向父類傳遞參數(shù);子類可以共享父類引用的屬性;

缺點(diǎn): 實(shí)例不是父類的實(shí)例;只能繼承父類的實(shí)例屬性和方法;無(wú)法實(shí)現(xiàn)函數(shù)復(fù)用,每個(gè)子類都有父類實(shí)例函數(shù)的副本,影響性能;

實(shí)例繼承

function Baby (name) {
 var instance = new Person();
 instance.name = name || 'Coder';
 return instance;
}
let baby = new Baby();
console.log(baby.name); // Coder
baby.sleep() // 朕正在睡覺(jué)!

優(yōu)點(diǎn): 不限制調(diào)用方式,返回的對(duì)象具有相同的效果;

缺點(diǎn): 不支持多繼承;實(shí)例是父類的實(shí)例,不是子類的實(shí)例;

拷貝繼承

// 定義一個(gè)嬰兒來(lái)繼承人的父類
function Baby (name) {
 var person = new Person();
 for (let p in person){
  Baby.prototype[p] = person[p];
 }
 Baby.prototype.name = name || 'Coder';
}
let baby = new Baby();
console.log(baby.name); // Coder
baby.sleep() // 朕正在睡覺(jué)!

優(yōu)點(diǎn): 支持多繼承;

缺點(diǎn): 效率較低,內(nèi)存占用高;無(wú)法獲取父類不可枚舉的方法;

注意:不可枚舉的方法是不能使用for in訪問(wèn)到的方法

組合繼承

// 定義一個(gè)嬰兒來(lái)繼承人的父類
function Baby (name) {
 Person.call(this);
 this.name = name || 'Coder';
}
Baby.prototype = new Person();
Baby.prototype.constructor = Baby;

let baby = new Baby();
console.log(baby.name); // Coder
baby.eat('milk'); // 朕現(xiàn)在吃的食物是:milk

優(yōu)點(diǎn): 不存在引用屬性共享問(wèn)題,可以傳參,函數(shù)可復(fù)用;

缺點(diǎn): 調(diào)用兩次構(gòu)造函數(shù),生成了兩份實(shí)例;

寄生組合繼承

// 定義一個(gè)嬰兒來(lái)繼承人的父類
function Baby (name) {
 Person.call(this);
 this.name = name || 'Coder';
}
(function () {
 let Super = function () {};
 Super.prototype = Person.prototype;
 Baby.prototype = new Super();
})();

let baby = new Baby();
console.log(baby.name); // Coder
baby.eat('milk'); // 朕現(xiàn)在吃的食物是:milk

優(yōu)點(diǎn): 整合了以上幾種繼承的優(yōu)點(diǎn);

缺點(diǎn): 實(shí)現(xiàn)復(fù)雜;

ES6的class

ES6 提供了更接近傳統(tǒng)語(yǔ)言的寫(xiě)法,引入了 Class(類)這個(gè)概念,作為對(duì)象的模板。通過(guò)class關(guān)鍵字,可以定義類?;旧希珽S6的class可以看作只是一個(gè)語(yǔ)法糖,它的絕大部分功能,ES5 都可以做到,新的class寫(xiě)法只是讓對(duì)象原型的寫(xiě)法更加清晰、更像面向?qū)ο缶幊痰恼Z(yǔ)法而已。

可以像如下定義:

class Person {
 constructor (name) {
  this.name = name;
 }
 sleep () {
  console.log('朕正在睡覺(jué)!');
 }
 eat (food) {
  console.log('朕現(xiàn)在吃的食物是:' + food);
 }
}

let person = new Person('小端');
console.log(person.name); // 小端
person.eat('milk'); // 朕現(xiàn)在吃的食物是:milk

ES6 class的繼承

// 定義一個(gè)嬰兒來(lái)繼承人的父類
class Baby extends Person {
 constructor(name){
  super(name);
 }
}
let baby = new Baby('小端');
console.log(baby.name); // 小端
baby.eat('milk'); // 朕現(xiàn)在吃的食物是:milk

關(guān)于Javascript中對(duì)象和繼承的關(guān)系是什么就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。

本文題目:Javascript中對(duì)象和繼承的關(guān)系是什么
標(biāo)題來(lái)源:http://aaarwkj.com/article34/pdejpe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)網(wǎng)站制作、網(wǎng)站排名、品牌網(wǎng)站建設(shè)搜索引擎優(yōu)化、響應(yīng)式網(wǎng)站、網(wǎng)站改版

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名
一区二区中文字幕精品| 欧美日韩国产一区二区的| 狼人私人影院在线观看| 日韩高清精品一区二区| 亚洲欧美国产精品久久久| 亚洲国产av国产av| 国产午夜精品自拍视频| 中文字幕有码av海量| 国外男女性生活在线视频| 一区二区三区欧美日韩| 欧美精品国产亚洲另类| 国产高清自拍视频免费| 午夜高清影院免费观看| 九九热视频在线观看色| 欧美一区二区三区va| 高清日本一区二区三区不卡片| 91九色精品视频在线观看| 四虎影视国产精品久久| 中文字幕在线视频黄字幕| 色香蕉精品国产综合| 亚洲成在人线免费观看| 亚洲综合偷拍欧美一区日韩| 国产系列在线播放一区二区三区 | 亚洲国产欲色有一二欲色| 亚洲日本韩国一区二区| 日韩欧美国产成人在线观看| 日本精品人妻一区二区三区蜜桃| 欧美亚洲综合日韩精品区| 国产l精品国产亚洲区久久| 亚洲精品国产av一区二区三区| av欧美激情在线观看| 中文字幕一区精品日韩| 日本午夜视频一区二区| 亚洲激情人妻小说网| 国产精品一区二区日韩新区| 在线看岛国毛片十八禁| 国产成人精品久久一区二区三区 | 亚洲av日韩av一区| 中文字幕三级电影天堂| 你懂的免费视频中文字幕| 日韩无砖区2021不卡|