成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

JavaScript實(shí)現(xiàn)函數(shù)重載

QLQ / 1839人閱讀

摘要:我們知道,函數(shù)可以隨意傳遞任意數(shù)量任意類型的參數(shù),那么它有沒有重載呢答案是有的,下面我們通過種方法來實(shí)現(xiàn)的函數(shù)重載。因此,每次調(diào)用,都會(huì)有一個(gè)執(zhí)行環(huán)境保存著當(dāng)時(shí)的和,所以在調(diào)用的時(shí)候可以找到當(dāng)時(shí)注入的,實(shí)現(xiàn)函數(shù)重載。

概念

重載是指函數(shù)或者方法有相同的名稱,但是參數(shù)個(gè)數(shù)或類型不相同的情形,這樣的同名不同參的函數(shù)或者方法之間,互相稱之為重載函數(shù)或方法。

我們知道,JavaScript函數(shù)可以隨意傳遞任意數(shù)量、任意類型的參數(shù),那么它有沒有重載呢?

答案是有的,下面我們通過3種方法來實(shí)現(xiàn)JavaScript的函數(shù)重載。

實(shí)現(xiàn) 0. 目標(biāo)

我們有一個(gè)people對(duì)象

var people = {
  values: ["Dean Edwards", "Sam Stephenson", "Alex Russell", "Dean Tom"]
};

想要實(shí)現(xiàn)一個(gè)find方法,不傳參數(shù)的時(shí)候,輸出所有名字,只傳1個(gè)參數(shù)的時(shí)候,輸出所有fristName和參數(shù)相同的名字,傳2個(gè)參數(shù)的時(shí)候,輸出所有firstName和lastName和2個(gè)參數(shù)分別相同的名字。

people.find();                          // ["Dean Edwards", "Sam Stephenson", "Alex Russell", "Dean Tom"]
people.find("Dean");                    // ["Dean Edwards", "Dean Tom"]
people.find("Dean", "Edwards");            // ["Dean Edwards"]
1. 利用arguments和switch實(shí)現(xiàn)重載
people.find = function () {
  switch (arguments.length) {
    case 0:
      return this.values;

    case 1:
      return this.values.filter((value) => {
        var firstName = arguments[0];
        return value.indexOf(firstName) !== -1 ? true : false;
      });

    case 2:
      return this.values.filter((value) => {
        var fullName = `${arguments[0]} ${arguments[1]}`;
        return value.indexOf(fullName) !== -1 ? true : false;
      });
  }
};

console.log(people.find());                 // ["Dean Edwards", "Sam Stephenson", "Alex Russell", "Dean Tom"]
console.log(people.find("Dean"));           // ["Dean Edwards", "Dean Tom"]
console.log(people.find("Dean", "Edwards"));   // ["Dean Edwards"]

這種方式大家肯定都能看懂,就不多說啦。

2. 利用arguments和閉包實(shí)現(xiàn)重載
function addMethod (object, name, fn) {
  // 把前一次添加的方法存在一個(gè)臨時(shí)變量old中
  var old = object[name];

  // 重寫object[name]方法
  object[name] = function () {
    if (fn.length === arguments.length) {
      // 如果調(diào)用object[name]方法時(shí),如果實(shí)參和形參個(gè)數(shù)一致,則直接調(diào)用
      return fn.apply(this, arguments);
    } else if (typeof old === "function") {
      // 如果實(shí)參形參不一致,判斷old是否是函數(shù),如果是,就調(diào)用old
      return old.apply(this, arguments);
    }
  };
}

addMethod(people, "find", function() {
  return this.values;
});

addMethod(people, "find", function(firstName) {
  return this.values.filter((value) => {
    return value.indexOf(firstName) !== -1 ? true : false;
  });
});

addMethod(people, "find", function(firstName, lastName) {
  return this.values.filter((value) => {
    var fullName = `${firstName} ${lastName}`;
    return value.indexOf(fullName) !== -1 ? true : false;
  });
});

console.log(people.find());                     // ["Dean Edwards", "Sam Stephenson", "Alex Russell", "Dean Tom"]
console.log(people.find("Dean"));               // ["Dean Edwards", "Dean Tom"]
console.log(people.find("Dean", "Edwards"));    // ["Dean Edwards"]

這里addMethod(object, name, fn)方法是核心。我們著重分析一下為什么這里會(huì)有閉包,可以保存上一個(gè)注冊(cè)的函數(shù)。

function addMethod (object, name, fn) {
  // object, name, fn是傳入的3個(gè)參數(shù)
  var old = object[name];

  object[name] = function () {
    // 這里對(duì)old和fn進(jìn)行了引用
    if (fn.length === arguments.length) {
      return fn.apply(this, arguments);
    } else if (typeof old === "function") {
      return old.apply(this, arguments);
    }
  };
}

object是另外一個(gè)引用對(duì)象,它的一個(gè)方法中引用了old和fn,所以對(duì)于addMethod來說,它的局部變量在addMethod函數(shù)執(zhí)行完后,仍然被另外的變量所引用,導(dǎo)致它的執(zhí)行環(huán)境無法銷毀,所以產(chǎn)生了閉包。

因此,每次調(diào)用addMethod,都會(huì)有一個(gè)執(zhí)行環(huán)境保存著當(dāng)時(shí)的old和fn,所以在調(diào)用people.find()的時(shí)候可以找到當(dāng)時(shí)注入的fn,實(shí)現(xiàn)函數(shù)重載。

3. 利用Proxy和arguments實(shí)現(xiàn)重載
var proxy = new Proxy(people, {
  get: function (target, key, receiver) {
    if (key === "find") {
      return function () {
        switch (arguments.length) {
          case 0:
            return this.values;
      
          case 1:
            return this.values.filter((value) => {
              var firstName = arguments[0];
              return value.indexOf(firstName) !== -1 ? true : false;
            });
      
          case 2:
            return this.values.filter((value) => {
              var fullName = `${arguments[0]} ${arguments[1]}`;
              return value.indexOf(fullName) !== -1 ? true : false;
            });
        }
      };
    }

    return Reflect.get(target , key , receiver);
  },

  set: function (target, key, value, receiver) {
    return Reflect.set(target, key, value, receiver);
  }
});

console.log(proxy.find());                     // ["Dean Edwards", "Sam Stephenson", "Alex Russell", "Dean Tom"]
console.log(proxy.find("Dean"));               // ["Dean Edwards", "Dean Tom"]
console.log(proxy.find("Dean", "Edwards"));   // ["Dean Edwards"]

這樣寫其實(shí)感覺有點(diǎn)畫蛇添足了,就當(dāng)成是另外一種思路吧。

總結(jié)

JavaScript可以實(shí)現(xiàn)函數(shù)重載,主要有兩種思想:

利用arguments類數(shù)組來判斷接收參數(shù)的個(gè)數(shù)

利用閉包保存以前注冊(cè)進(jìn)來的同名函數(shù)

歡迎關(guān)注我的公眾號(hào)

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/97143.html

相關(guān)文章

  • 重名就會(huì)被覆蓋?那JavaScript中是如何實(shí)現(xiàn)重載的呢?

    摘要:但是我們知道中是沒有重載的為什么沒重載不是的特性也會(huì)有的嗎,因?yàn)楹竺娑x的函數(shù)會(huì)覆蓋前面的同名函數(shù),但是重載那么好用,我們想在實(shí)現(xiàn)函數(shù)重載該怎么辦呢今天就來給大家講講在里面實(shí)現(xiàn)函數(shù)重載的兩個(gè)思路。這就是閉包的核心作用。 大家都知道,所謂重載,就是一組相同的函數(shù)名,有不同個(gè)數(shù)的參數(shù),在使用時(shí)調(diào)用一個(gè)函數(shù)名,傳入不同參數(shù),根據(jù)你的參數(shù)個(gè)數(shù),來決定使用不同的函數(shù)!重載這個(gè)在JAVA這些經(jīng)典的...

    mozillazg 評(píng)論0 收藏0
  • JavaScript函數(shù)重載

    摘要:實(shí)現(xiàn)函數(shù)重載函數(shù)重載,是等編程語言中具有的一項(xiàng)特性,這項(xiàng)特性允許創(chuàng)建數(shù)項(xiàng)名稱相同但輸入輸出類型或個(gè)數(shù)不同的子程序,它可以簡單地稱為一個(gè)單獨(dú)功能可以執(zhí)行多項(xiàng)任務(wù)的能力。其它在中加入了類型,它自帶函數(shù)重載。 JavaScript實(shí)現(xiàn)函數(shù)重載 函數(shù)重載(function overloading),是 Ada、C++、C#、D、Java等編程語言中具有的一項(xiàng)特性,這項(xiàng)特性允許創(chuàng)建數(shù)項(xiàng)名稱相同...

    SnaiLiu 評(píng)論0 收藏0
  • JavaScript中的函數(shù)重載(Function overloading)

    摘要:說明中沒有真正意義上的函數(shù)重載。先看第一種辦法,通過對(duì)象來實(shí)現(xiàn)對(duì)象,是函數(shù)內(nèi)部的一個(gè)類數(shù)組對(duì)象,它里面保存著調(diào)用函數(shù)時(shí),傳遞給函數(shù)的所有參數(shù)。 說明 JavaScript 中沒有真正意義上的函數(shù)重載。 函數(shù)重載 函數(shù)名相同,函數(shù)的參數(shù)列表不同(包括參數(shù)個(gè)數(shù)和參數(shù)類型),根據(jù)參數(shù)的不同去執(zhí)行不同的操作。 我們舉個(gè)例子看看 function overload(a){ conso...

    inapt 評(píng)論0 收藏0
  • JavaScript函數(shù)重載

    摘要:譯者按之父巧妙地利用了閉包,實(shí)現(xiàn)了函數(shù)重載。在一個(gè)業(yè)余項(xiàng)目中,我寫了一個(gè)簡單的函數(shù),用于實(shí)現(xiàn)函數(shù)重載。而所謂函數(shù)重載,就是函數(shù)名稱一樣,但是輸入輸出不一樣。 譯者按: jQuery之父John Resig巧妙地利用了閉包,實(shí)現(xiàn)了JavaScript函數(shù)重載。 原文: JavaScript Method Overloading 譯者: Fundebug 為了保證可讀性,本文采用意...

    testHs 評(píng)論0 收藏0
  • JavaScript之模擬函數(shù)重載

    摘要:背景高級(jí)程序設(shè)計(jì)中提及,不支持函數(shù)重載。若出現(xiàn)函數(shù)名稱相同情況下,后者覆蓋前者,故此不會(huì)出現(xiàn)重載的情況。維基百科場景例如,一個(gè)工廠有著數(shù)量級(jí)的員工,期望通過姓名找到某一員工或某類員工,使用同一個(gè)方法通過透傳參數(shù)個(gè)數(shù)去查找員工。 背景 ???????《JavaScript高級(jí)程序設(shè)計(jì)》中提及,JavaScript 不支持函數(shù)重載。若出現(xiàn)函數(shù)名稱相同情況下,后者覆蓋前者,故此不會(huì)出現(xiàn)重載...

    chenjiang3 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<