js中apply()和call()的區(qū)別與用法實(shí)例分析
本文實(shí)例講述了js中apply()和call()的區(qū)別與用法。分享給大家供大家參考,具體如下:
每個(gè)函數(shù)都包括兩個(gè)非繼承而來的方法:apply()和call()。兩者用途都是在特定的作用域中調(diào)用函數(shù),等于重新設(shè)置了函數(shù)體內(nèi)this對(duì)象的值。
兩者區(qū)別僅在于接收參數(shù)方式不同,apply()第一個(gè)參數(shù)是調(diào)用apply的函數(shù)運(yùn)行的作用域,的第二個(gè)參數(shù)可以是Array的實(shí)例(數(shù)組),也可以是arguments對(duì)象,call()第一個(gè)參數(shù)是this的值沒有變化,而其余參數(shù)都直接傳遞給函數(shù)(也就是逐個(gè)列舉出來)。
如果要傳入的是數(shù)組或arguments對(duì)象,apply會(huì)更方便。
可以看到apply()和call()可以傳遞參數(shù)。更有用的是,兩者還可以擴(kuò)充函數(shù)運(yùn)行的作用域:
var obj = {color:'red'};
window.color = 'blue';
function getcolor(){
console.log(this.color)
};
getcolor.apply(obj); //red
getcolor.apply(window); //blue
getcolor.apply(this); //blue
使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun,測(cè)試運(yùn)行結(jié)果如下:

一個(gè)重要的用法:
var values = [1,2,3,4,5,4,3,2,1]; var max = Math.max.apply(Math,values); console.log(max); //5
使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun,測(cè)試運(yùn)行結(jié)果如下:

這個(gè)實(shí)際上是利用apply()接收數(shù)組,方便了傳參。而apply的第一個(gè)參數(shù)改為null或者空字符串均可。
此外還有bind()方法會(huì)創(chuàng)建一個(gè)函數(shù)的實(shí)例,其this值指向傳給bind()的值:
window.color = 'red';
var o = {color:'blue'};
function sayColor(){
console.log(this.color)
};
var objSayColor = sayColor.bind(o);
objSayColor(); //blue
使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun,測(cè)試運(yùn)行結(jié)果如下:

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript常用函數(shù)技巧匯總》、《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)文章
JavaScript實(shí)現(xiàn)圖片滑動(dòng)切換的代碼示例分享
這篇文章主要介紹了JavaScript實(shí)現(xiàn)圖片滑動(dòng)切換的代碼示例分享,能夠控制包括滑動(dòng)時(shí)間和切換數(shù)量等,需要的朋友可以參考下2016-03-03
javascript學(xué)習(xí)筆記(七)利用javascript來創(chuàng)建和存儲(chǔ)cookie
今天把javascript如何用來創(chuàng)建及存儲(chǔ)cookie復(fù)習(xí)了一下,其中的一點(diǎn)體會(huì)拿出來和大家討論,懇請(qǐng)高手指點(diǎn)一二。2011-04-04
淺談javascript的數(shù)據(jù)類型檢測(cè)
剖析一下javascript的數(shù)據(jù)類型。這一次我們只簡(jiǎn)單討論下javascript的數(shù)據(jù)類型檢測(cè),繼續(xù)期望大家踴躍發(fā)表意見,尤其歡迎高手拍磚。2010-07-07
JavaScript如何實(shí)現(xiàn)組合列表框中元素移動(dòng)效果
在頁面中有兩個(gè)列表框,需要把其中一個(gè)列表框的元素移動(dòng)到另一個(gè)列表框,怎么實(shí)現(xiàn)此功能呢,下面通過本文給大家介紹JavaScript如何實(shí)現(xiàn)組合列表框中元素移動(dòng)效果,感興趣的朋友一起學(xué)習(xí)吧2016-03-03
原生js實(shí)現(xiàn)無限循環(huán)輪播圖效果
本文主要介紹了原生js實(shí)現(xiàn)無限循環(huán)輪播圖效果的示例代碼。具有很好的參考價(jià)值,下面跟著小編一起來看下吧2017-01-01
JS字符串分割方法整理匯總示例講解(3種截取方法和6個(gè)輔助方法)
JavaScript在開發(fā)中常常會(huì)需要截取字符串,而JS提供了slice()?、substring()、substr()?3種方法實(shí)現(xiàn)截取操作。另外還有字符串相關(guān)的6種輔助方法:indexOf()、lastIndexOf()、split()、join()、concat()、charAt()?。2023-02-02

