在JS Array 中支持兩個方法,shift() 和pop(),分別是指從一個數據中的最前面和最後面刪除一個值,並返刪除值。看一個示例就明白了:
複製代碼代碼如下:
var arr = ['s','o','f','i','s','h'];
arr.shift(); // 返回's'
arr; // 目前是['o','f','i','s','h']
arr.pop() // 返回'h'
arr // 目前是['o','f','i','s']
在很多JS 框架中可以很常見的是,一個方法提供你傳幾個參數,而這些參數中,部分是可以忽略的,這些可以忽略的點可能是第一個,也可能是最後一個。傳統的寫法是判斷參數有沒有存在,或者參數的個數來決定最終取值。
這裡,我們可以利用函數的arguments 對象,以及Array 中的shift 和pop 來實現靈活的應用。
一、使用shift
如何實現一個.bind() 方法,讓fn api 如下:
複製代碼代碼如下:
// fn 的作用域限定於object 下
// 除object 外,所有bind 方法的參數都將傳給fn
fn.bind(object, param1, param2, [, paramN]);
看一個實例先。當然,這例子可能更為重要的是call和apply 的應用。不過,我們想要說的是shift 的應用:
複製代碼代碼如下:
// 來自Prototype.js 的[`.bind`](http://www.prototypejs.org/api/function/bind) 方法
Function.prototype.bind = function(){
var fn = this,
args = Array.prototype.slice.call(arguments),
object = args.shift();
return function(){
return fn.apply(object,
args.concat(Array.prototype.slice.call(arguments)));
};
};
我們可以利用對arguments 對象(array-like object,需要轉換成真正的array)進行shift 來取出,像這個方法,主要利用它們來分出作為作用域的object,然後巧妙地把餘下的參數數組傳給fn,即調用我們想限定到object 作用域內的函數。
二、使用pop
最近在試用seajs,我們就拿它的一個api 來說吧:
複製代碼代碼如下:
define(id, dependencies, callback)
這個定義一個模塊的api,id 和dependencies 都是可以省略的。這裡,如何實現這個支持呢?如果使用if 來判斷,真就得if (arguments === 1) {...} elseif ... 一大堆了。當然,這樣有時候也有好處的(?,想想)。這裡,我們可能用來pop 來方便實現這樣的支持:
複製代碼代碼如下:
var define = function(){
// 取出這個callback
var args = [].slice.call(arguments)
fn = args.pop();
// 做點其他神馬事
fn.apply(null, args)
// ...
},
callback = function(){
var args = arguments, i = 0, len = args.length;
if(len === 0) console.log('只有一個callback');
for(;i<len;i++) {
console.log(args[i]);
}
}
// 看看他們三個的執行結果
define(callback);
define('有兩個參數', callback);
define('有三個參數', 'hello world', callback);
前兩天和同事除到一些JS 中的技巧時引用的一個東西。雖然總叫自己不要太沉浸於代碼中,但代碼,不僅僅是JS,總是給我們太多樂趣。如何不喜歡。哈哈。