亚洲中字慕日产2020,大陆极品少妇内射AAAAAA,无码av大香线蕉伊人久久,久久精品国产亚洲av麻豆网站

資訊專欄INFORMATION COLUMN

原生js實現(xiàn)each方法

wh469012917 / 1164人閱讀

摘要:里面有個方法,將循環(huán)操作簡化便捷。隨后出了個方法,兩個雖然用法相近,但是不能處理對象類型。且無法通過達到效果。在不使用的方法時,該如何處理或者說用原生如何來實現(xiàn)前些前寫了個類庫其中就實現(xiàn)了該方法。

jquery里面有個each方法,將循環(huán)操作簡化、便捷。
隨后es出了個forEach方法,兩個雖然用法相近,但是不能處理對象類型。且無法通過return true達到continue效果。
此外還有個every方法,該方法雖然可以實現(xiàn)continue效果,但是在處理類數(shù)組與對象類型時,完全無用。

在不使用jqueryeach方法時,該如何處理;或者說用原生如何來實現(xiàn)?
前些前寫了個類庫: jTool, 其中就實現(xiàn)了該方法。

簡單實現(xiàn):
// 通過字面量方式實現(xiàn)的函數(shù)each
var each =  function(object, callback){
  var type = (function(){
          switch (object.constructor){
            case Object:
                return "Object";
                break;
            case Array:
                return "Array";
                break;
            case NodeList:
                return "NodeList";
                break;
            default:
                return "null";
                break;
        }
    })();
    // 為數(shù)組或類數(shù)組時, 返回: index, value
    if(type === "Array" || type === "NodeList"){
        // 由于存在類數(shù)組NodeList, 所以不能直接調用every方法
        [].every.call(object, function(v, i){
            return callback.call(v, i, v) === false ? false : true;
        });
    }
    // 為對象格式時,返回:key, value
    else if(type === "Object"){
        for(var i in object){
            if(callback.call(object[i], i, object[i]) === false){
                break;
            }
        }
    }
}
我們來try一下, 測試下數(shù)組、對象、類數(shù)組類型及中斷效果 數(shù)組類型
var _array = [1,2,3,4];
each(_array, function(i, v){
  console.log(i + ": " + v);
});

輸出如下:

對象類型

var object = {a:1, b:2, c:3}
each(object, function(i, v){
console.log(i + ": " + v);
});
輸出如下:

類數(shù)組類型
var ele = document.querySelectorAll("div");
each(ele, function(i, v){
  console.log(i + ": " + v);
});

輸出如下:

增加中斷條件
var object2 = {name:"baukh", age: "29", six:"男", url: "www.lovejavascript.com",}
each(object2, function(i, v){
  if(i === "age"){ //如果存在鍵值為age的屬性時,則輸出警告,用于實現(xiàn)continue效果
    console.log("存在鍵值為age,這家伙已經(jīng)"+v+"歲了");
    return true;
  }
  if(i === "six" && v === "男"){//如果存在鍵值為age的屬性時,則輸出跳出,用于實現(xiàn)break效果
    console.log("存在鍵值為six,是個男的,不用關注了~");
    return false;
  }
  console.log(i + ": " + v);
});

輸出如下:

從結果可以看出來,each方法已經(jīng)實現(xiàn)了jquery的each功能。且實現(xiàn)如此簡單~

隨筆一行
這是前端最好的時代, 這也是前端最壞的時代。 眾多前端框架滿天飛,隨著 jQuery 在前端行業(yè)的慢慢弱化,總是會有一種斯人遠去,何者慰籍的感覺?;ッ惆?,各位。

另推薦個表格組件gridManager

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

轉載請注明本文地址:http://www.ezyhdfw.cn/yun/109811.html

相關文章

  • 原生js實現(xiàn)on與off 方法

    摘要:所以僅對參數(shù)進行了處理,功能上沒有實現(xiàn)子選擇器事件觸發(fā)后執(zhí)行的函數(shù)指定事件是否在捕獲或冒泡階段執(zhí)行事件句柄在捕獲階段執(zhí)行默認。 使用過jQuery的同學,應該對事件綁定方法 .on() .off() 有一定的了解。 在個人類庫jTool 中實現(xiàn)了這兩個方法,這里就來細說下原生實現(xiàn)方式。 實現(xiàn)方式 以下為個人類庫jTool 中 Event 實現(xiàn)方式。代碼中使用到一個基礎方法對象utili...

    tanglijun 評論0 收藏0
  • 解釋一下為什么我很少jQuery

    摘要:為什么有一個東西,叫,它是一個快速輕量級跨平臺的框架。同時,它也是這個世界上最輕量級的框架沒有之一它有多快如下我們在里引入比上面更快的方法是什么沒有代碼是的,就是沒有代碼,因為實在太強了,以至于所有的瀏覽器在年前內置了它。 這里聲明一下,這不是反jQuery的文章,jQuery作為一個js庫給大家的項目開發(fā)帶來很多便利,但有時候仔細想想,我們真的需要jQuery嗎?一年前的lpisme...

    happyhuangjinjin 評論0 收藏0
  • Zepto核心模塊之工具方法拾遺

    摘要:舉例需要注意的是,此時回調函數(shù)中的指向的就是數(shù)組或者對象的某一項。中提供的拷貝方法,默認為淺拷貝,如果第一個參數(shù)為布爾值則表示深拷貝。 前言 平時開發(fā)過程中經(jīng)常會用類似each、map、forEach之類的方法,Zepto本身也把這些方法掛載到$函數(shù)身上,作為靜態(tài)方法存在,既可以給Zepto的實例使用,也能給普通的js對象使用。今天我們主要針對其提供的這些api做一些源碼實現(xiàn)分析。 源...

    Alex 評論0 收藏0
  • Zepto核心模塊之工具方法拾遺

    摘要:舉例需要注意的是,此時回調函數(shù)中的指向的就是數(shù)組或者對象的某一項。中提供的拷貝方法,默認為淺拷貝,如果第一個參數(shù)為布爾值則表示深拷貝。 前言 平時開發(fā)過程中經(jīng)常會用類似each、map、forEach之類的方法,Zepto本身也把這些方法掛載到$函數(shù)身上,作為靜態(tài)方法存在,既可以給Zepto的實例使用,也能給普通的js對象使用。今天我們主要針對其提供的這些api做一些源碼實現(xiàn)分析。 源...

    lcodecorex 評論0 收藏0

發(fā)表評論

0條評論

wh469012917

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<