亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JS中call和apply函數(shù)用法實(shí)例分析

 更新時(shí)間:2018年06月20日 09:22:36   作者:輘酆  
這篇文章主要介紹了JS中call和apply函數(shù)用法,結(jié)合實(shí)例形式較為詳細(xì)的分析了call和apply函數(shù)繼承功能的使用方法、區(qū)別及操作注意事項(xiàng),需要的朋友可以參考下

本文實(shí)例講述了JS中call和apply函數(shù)用法。分享給大家供大家參考,具體如下:

call 函數(shù)

語法

obj.call(thisObj,arg[,arg2[,arg3[,...agr]]]);

簡介

thisObj繼承obj的屬性和方法(obj原型鏈上的屬性和方法不能被繼承),后面的參數(shù)會(huì)當(dāng)成obj的參數(shù)安裝順序傳遞進(jìn)去。

示例

function animal(type,nickname){
    this.type = type;
    this.nickname = nickname;
    this.sayHello = function(){
      return 'hello';
    }
}
function cat(name,type,nickname){
    this.name = name;
    //cat繼承animal
    animal.call(this,type,nickname);
}
console.log(new cat('wsscat','cut','tom'));
/*
cat {
 name: 'wsscat',
 type: 'cut',
 nickname: 'tom',
 sayHello: [Function] }
*/

apply 函數(shù)

語法

obj.apply(this[,argArray]);

簡介

apply和call的作用差不多,都可以用來繼承,區(qū)別在與apply只有兩個(gè)參數(shù),第二個(gè)參數(shù)必須是數(shù)組或者arguments對(duì)象。否則會(huì)報(bào)TypeError錯(cuò)誤。如果繼承的對(duì)象obj有多個(gè)參數(shù),則會(huì)吧argArray的參數(shù)依次對(duì)應(yīng)obj的每個(gè)參數(shù)。

示例

function animal(type,nickname){
    this.type = type;
    this.nickname = nickname;
    this.syaHello = function(){
      return 'hello';
    }
}
function cat(name,type,nickname){
    this.name = name;
    animal.apply(this,arguments);
}
console.log(new cat('wsscat','cut','tom'));
/*
cat {
 name: 'wsscat',
 type: 'wsscat',
 nickname: 'cut',
 syaHello: [Function] }
*/

總結(jié)

callapply功能是相同的。

相同點(diǎn)在于都是用于對(duì)象的繼承,第一個(gè)參數(shù)都是thisObj.

不同點(diǎn)在于call可以有多個(gè)參數(shù),從第二個(gè)參數(shù)開始往后的參數(shù)會(huì)依次傳給被繼承的對(duì)象做參數(shù)。apply只有兩個(gè)參數(shù),第二個(gè)參數(shù)必須是數(shù)組類型或者arguments對(duì)象類型,而且他會(huì)把數(shù)組中的元素依次傳遞給被繼承的對(duì)象做參數(shù)。

通過以上幾點(diǎn),我們可以得到如果被繼承的對(duì)象只有一個(gè)參數(shù)的可以使用call,如果被繼承的對(duì)象有多個(gè)參數(shù)的,建議使用apply.

補(bǔ)充

js中可以實(shí)現(xiàn)多繼承,只需要調(diào)用多次call或apply即可。如:

function animal(type,nickname){
    this.type = type;
    this.nickname = nickname;
    this.syaHello = function(){
      return 'hello';
    }
}
function wscat(name,age){
    this.name = name;
    this.age = age;
    this.sayMe = function(){
      return 'my name:' + this.name + ', age:' + this.age;
    }
}
function cat(name,age,type,nickname){
    //第一種使用call
    animal.call(this,type,nickname);
    wscat.call(this,name,age);
    //第二種使用apply
    //animal.apply(this,[type,nickname]);
    //wscat.apply(this,[name,age]);
}
console.log(new cat('wscat',2,'cat','tom');
/*
cat {
 type: 'cat',
 nickname: 'tom',
 syaHello: [Function],
 name: 'wscat',
 age: 2,
 sayMe: [Function] }
*/

繼承的優(yōu)化

如果構(gòu)造函數(shù)this綁定了太多的屬性(比如一些共用的函數(shù)),示例化后就會(huì)照成浪費(fèi)(因?yàn)閠his里的屬性和方法實(shí)例化后會(huì)復(fù)制一份給新對(duì)象,多個(gè)對(duì)象之間的屬性和方法互不干涉,對(duì)于一些可以共用的方法來就會(huì)造成浪費(fèi))

所以我們一般把共用的函數(shù)都放在原型鏈(prototype)上。但是使用call和apply無法繼承原型鏈上的屬性和方法。

因此我們可以使用混合的而寫法,使用原型鏈和(applycall)組合的方式進(jìn)行繼承。

讓子的原型鏈指向父的示例(父的實(shí)例化對(duì)象)。如:

cat.prototype = new animal();

讓父的屬性創(chuàng)建在子的this上。如:

animal.call(this[,arg]);
//animal.apply(this[,argArray]);

具體代碼如下:

function animal(type,nickname){
    this.type = type;
    this.nickname = nickname;
}
animal.prototype.sayHello = function(){
    return 'hello';
}
function wscat(name,age){
    this.name = name;
    this.age = age;
} 
//這里是關(guān)鍵,原型鏈只能單繼承,
//不能同時(shí)繼承多個(gè)原型鏈,所以要一級(jí)一級(jí)來。
wscat.prototype = new animal();
wscat.prototype.sayMe = function(){
    return 'my name:' + this.name + ', age:' + this.age;
}
function cat(name,age,type,nickname){
    animal.call(this,type,nickname);
    wscat.call(this,name,age);
}
cat.prototype = new wscat();
var obj = new cat('wscat',10,'cat','tom');
console.log(obj);
//animal { type: 'cat', nickname: 'tom', name: 'wscat', age: 10 }
console.log(obj.sayHello());//hello
console.log(obj.sayMe());
/*
    my name:wscat, age:10
*/

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)

希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • html2canvas+jspdf實(shí)現(xiàn)下載pdf文件并添加水印

    html2canvas+jspdf實(shí)現(xiàn)下載pdf文件并添加水印

    這篇文章主要為大家詳細(xì)介紹了如何使用html2canvas + jspdf進(jìn)行下載pdf文件添加水印,以及echarts圖片防止截?cái)嗵幚?有需要的小伙伴可以了解下
    2024-10-10
  • 使用JS實(shí)現(xiàn)圖片展示瀑布流效果(簡單實(shí)例)

    使用JS實(shí)現(xiàn)圖片展示瀑布流效果(簡單實(shí)例)

    下面小編就為大家?guī)硪黄褂肑S實(shí)現(xiàn)圖片展示瀑布流效果(簡單實(shí)例)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-09-09
  • 詳解JavaScript實(shí)現(xiàn)監(jiān)聽路由變化

    詳解JavaScript實(shí)現(xiàn)監(jiān)聽路由變化

    前端實(shí)現(xiàn)路由變化主要有兩種方式,本文主要介紹了這兩種方法的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • JS異步錯(cuò)誤捕獲的一些事小結(jié)

    JS異步錯(cuò)誤捕獲的一些事小結(jié)

    這篇文章主要給大家介紹了關(guān)于JS異步錯(cuò)誤捕獲的一些事,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Javascript具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • Layui多選只有最后一個(gè)值的解決方法

    Layui多選只有最后一個(gè)值的解決方法

    今天小編就為大家分享一篇Layui多選只有最后一個(gè)值的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • 精通Javascript系列之?dāng)?shù)值計(jì)算

    精通Javascript系列之?dāng)?shù)值計(jì)算

    在JS中如果希望某個(gè)變量包含一個(gè)數(shù)值,那么無需限定其必須是整數(shù)或者是浮點(diǎn)數(shù),下面來個(gè)例子
    2011-06-06
  • js編寫trim()函數(shù)及正則表達(dá)式的運(yùn)用

    js編寫trim()函數(shù)及正則表達(dá)式的運(yùn)用

    js中本身是沒有trim函數(shù)的,不過你可以自己寫一個(gè),下面的實(shí)現(xiàn)方法是用到了正則表達(dá)式,效率不錯(cuò),并把這三個(gè)方法加入String對(duì)象的內(nèi)置方法中去
    2013-10-10
  • js中opener與parent的區(qū)別詳細(xì)解析

    js中opener與parent的區(qū)別詳細(xì)解析

    本篇文章主要是對(duì)js中opener與parent的區(qū)別進(jìn)行了詳細(xì)的介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助
    2014-01-01
  • 詳解如何利用chatgpt保護(hù)您的js代碼

    詳解如何利用chatgpt保護(hù)您的js代碼

    這篇文章主要為大家介紹了如何利用chatgpt保護(hù)您的js代碼詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • JavaScript面試技巧之?dāng)?shù)組的一些不low操作

    JavaScript面試技巧之?dāng)?shù)組的一些不low操作

    這篇文章主要給大家介紹了關(guān)于JavaScript面試技巧之?dāng)?shù)組的一些不low操作的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用js具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03

最新評(píng)論