本文實(shí)例分析了JavaScript中call和apply方法的區(qū)別。分享給大家供大家參考,具體如下:
這兩個(gè)方法不經(jīng)常用,但是在某些特殊場(chǎng)合中是非常有用的,下面主要說下它們的區(qū)別:
	1、首先,JavaScript是一門面向?qū)ο蟮恼Z(yǔ)言,也就是說它有this的概念。而且JavaScript是一門動(dòng)態(tài)類型語(yǔ)言,為什么說它是動(dòng)態(tài)類型語(yǔ)言呢?因?yàn)镴avaScript在編譯時(shí)沒有類型檢查的過程,不會(huì)去檢查創(chuàng)建的對(duì)象類型,也不會(huì)去檢查傳遞的參數(shù)類型,所以它的變量類型在運(yùn)行期間是可以改變的。
	2、要知道call和apply都是為了改變某個(gè)函數(shù)運(yùn)行時(shí)的上下文(context)而存在的,也就是為了改變函數(shù),也可以說是對(duì)象(函數(shù)本身就是對(duì)象)內(nèi)部this的指向而存在的。
3、二者區(qū)別為:傳參數(shù)的方式不一樣,如下:
func.call(this, arg1, arg2);func.apply(this, [arg1, arg2]);
	上面也很清楚了,call傳參數(shù)時(shí),明確知道時(shí)幾個(gè)參數(shù)或者參數(shù)較少時(shí),比如arg1、arg2,挨個(gè)傳就是了;
	而apply第二個(gè)參數(shù)必須為一個(gè)數(shù)組,即將參數(shù)放進(jìn)數(shù)組中即可。
4、實(shí)例
(function(){ Array.prototype.push.call(arguments, 4);//arguments借用Array.prototype.push方法 console.log( arguments ); //輸出: [1, 2, 3, 4]})(1, 2, 3);var currying = function(fn){  var args = [];  return function(){    if( arguments.length === 0){      return fn.apply( this, args);    }    else{      [].push.apply( args, arguments);      return arguments.callee; //callee已棄用    }  }};var cost = (function(){ var money = 0; return function(0{   for(var i = 0,l - arguments.length;i<l;i++){     money += arguments[i];   }   return money; }})();調(diào)用:
var cost_ = currying(cost); //將cost轉(zhuǎn)化成curring函數(shù)cost_(1); cost_(2); alert(cost_()); //輸出:3
	解釋:通過currying(柯里化)的轉(zhuǎn)化,在cost_中傳入?yún)?shù)時(shí),未能得到值,而是將值存儲(chǔ)起來(lái),直到當(dāng)無(wú)參數(shù)傳入時(shí),輸出結(jié)果。
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
新聞熱點(diǎn)
疑難解答