在 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']
這里,我們可以利用函數的 arguments 對象,以及 Array 中的 shift 和 pop 來實現靈活的應用。
一、使用 shift
如何實現一個 .bind() 方法,讓 fn api 如下:
復制代碼 代碼如下:
// fn 的作用域限定于 object 下
// 除 object 外,所有 bind 方法的參數都將傳給 fn
fn.bind(object, param1, param2, [, paramN]);
復制代碼 代碼如下:
// 來自 Prototype.js 的 [`.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)));
      };
};
二、使用 pop
最近在試用 seajs,我們就拿它的一個 api 來說吧:
復制代碼 代碼如下:
define(id, dependencies, callback)
復制代碼 代碼如下:
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);
新聞熱點
疑難解答
圖片精選