摘要:里面有個(gè)方法,將循環(huán)操作簡(jiǎn)化便捷。隨后出了個(gè)方法,兩個(gè)雖然用法相近,但是不能處理對(duì)象類型。且無(wú)法通過(guò)達(dá)到效果。在不使用的方法時(shí),該如何處理或者說(shuō)用原生如何來(lái)實(shí)現(xiàn)前些前寫(xiě)了個(gè)類庫(kù)其中就實(shí)現(xiàn)了該方法。
jquery里面有個(gè)each方法,將循環(huán)操作簡(jiǎn)化、便捷。
隨后es出了個(gè)forEach方法,兩個(gè)雖然用法相近,但是不能處理對(duì)象類型。且無(wú)法通過(guò)return true達(dá)到continue效果。
此外還有個(gè)every方法,該方法雖然可以實(shí)現(xiàn)continue效果,但是在處理類數(shù)組與對(duì)象類型時(shí),完全無(wú)用。
在不使用jquery的each方法時(shí),該如何處理;或者說(shuō)用原生如何來(lái)實(shí)現(xiàn)?
前些前寫(xiě)了個(gè)類庫(kù): jTool, 其中就實(shí)現(xiàn)了該方法。
// 通過(guò)字面量方式實(shí)現(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ù)組時(shí), 返回: index, value if(type === "Array" || type === "NodeList"){ // 由于存在類數(shù)組NodeList, 所以不能直接調(diào)用every方法 [].every.call(object, function(v, i){ return callback.call(v, i, v) === false ? false : true; }); } // 為對(duì)象格式時(shí),返回:key, value else if(type === "Object"){ for(var i in object){ if(callback.call(object[i], i, object[i]) === false){ break; } } } }我們來(lái)try一下, 測(cè)試下數(shù)組、對(duì)象、類數(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);
});
輸出如下:
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的屬性時(shí),則輸出警告,用于實(shí)現(xiàn)continue效果 console.log("存在鍵值為age,這家伙已經(jīng)"+v+"歲了"); return true; } if(i === "six" && v === "男"){//如果存在鍵值為age的屬性時(shí),則輸出跳出,用于實(shí)現(xiàn)break效果 console.log("存在鍵值為six,是個(gè)男的,不用關(guān)注了~"); return false; } console.log(i + ": " + v); });
輸出如下:
從結(jié)果可以看出來(lái),each方法已經(jīng)實(shí)現(xiàn)了jquery的each功能。且實(shí)現(xiàn)如此簡(jiǎn)單~
隨筆一行
這是前端最好的時(shí)代, 這也是前端最壞的時(shí)代。 眾多前端框架滿天飛,隨著 jQuery 在前端行業(yè)的慢慢弱化,總是會(huì)有一種斯人遠(yuǎn)去,何者慰籍的感覺(jué)?;ッ惆桑魑?。
另推薦個(gè)表格組件gridManager
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/109811.html
摘要:所以僅對(duì)參數(shù)進(jìn)行了處理,功能上沒(méi)有實(shí)現(xiàn)子選擇器事件觸發(fā)后執(zhí)行的函數(shù)指定事件是否在捕獲或冒泡階段執(zhí)行事件句柄在捕獲階段執(zhí)行默認(rèn)。 使用過(guò)jQuery的同學(xué),應(yīng)該對(duì)事件綁定方法 .on() .off() 有一定的了解。 在個(gè)人類庫(kù)jTool 中實(shí)現(xiàn)了這兩個(gè)方法,這里就來(lái)細(xì)說(shuō)下原生實(shí)現(xiàn)方式。 實(shí)現(xiàn)方式 以下為個(gè)人類庫(kù)jTool 中 Event 實(shí)現(xiàn)方式。代碼中使用到一個(gè)基礎(chǔ)方法對(duì)象utili...
摘要:為什么有一個(gè)東西,叫,它是一個(gè)快速輕量級(jí)跨平臺(tái)的框架。同時(shí),它也是這個(gè)世界上最輕量級(jí)的框架沒(méi)有之一它有多快如下我們?cè)诶镆氡壬厦娓斓姆椒ㄊ鞘裁礇](méi)有代碼是的,就是沒(méi)有代碼,因?yàn)閷?shí)在太強(qiáng)了,以至于所有的瀏覽器在年前內(nèi)置了它。 這里聲明一下,這不是反jQuery的文章,jQuery作為一個(gè)js庫(kù)給大家的項(xiàng)目開(kāi)發(fā)帶來(lái)很多便利,但有時(shí)候仔細(xì)想想,我們真的需要jQuery嗎?一年前的lpisme...
摘要:舉例需要注意的是,此時(shí)回調(diào)函數(shù)中的指向的就是數(shù)組或者對(duì)象的某一項(xiàng)。中提供的拷貝方法,默認(rèn)為淺拷貝,如果第一個(gè)參數(shù)為布爾值則表示深拷貝。 前言 平時(shí)開(kāi)發(fā)過(guò)程中經(jīng)常會(huì)用類似each、map、forEach之類的方法,Zepto本身也把這些方法掛載到$函數(shù)身上,作為靜態(tài)方法存在,既可以給Zepto的實(shí)例使用,也能給普通的js對(duì)象使用。今天我們主要針對(duì)其提供的這些api做一些源碼實(shí)現(xiàn)分析。 源...
摘要:舉例需要注意的是,此時(shí)回調(diào)函數(shù)中的指向的就是數(shù)組或者對(duì)象的某一項(xiàng)。中提供的拷貝方法,默認(rèn)為淺拷貝,如果第一個(gè)參數(shù)為布爾值則表示深拷貝。 前言 平時(shí)開(kāi)發(fā)過(guò)程中經(jīng)常會(huì)用類似each、map、forEach之類的方法,Zepto本身也把這些方法掛載到$函數(shù)身上,作為靜態(tài)方法存在,既可以給Zepto的實(shí)例使用,也能給普通的js對(duì)象使用。今天我們主要針對(duì)其提供的這些api做一些源碼實(shí)現(xiàn)分析。 源...
閱讀 3027·2023-04-26 00:32
閱讀 510·2019-08-30 15:52
閱讀 2117·2019-08-30 15:52
閱讀 3362·2019-08-30 15:44
閱讀 3291·2019-08-30 14:09
閱讀 1424·2019-08-29 15:15
閱讀 3404·2019-08-28 18:12
閱讀 1088·2019-08-26 13:55