国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > JS > 正文

原生js實現(xiàn)each方法實例代碼詳解

2024-05-06 16:51:29
字體:
供稿:網(wǎng)友

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

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

簡單實現(xiàn):

js;" style="margin: 3px auto 0px; padding: 0px 0px 0px 5px; outline: none; background-image: initial; background-position: initial; background-size: initial; background-repeat: initial; background-attachment: initial; background-origin: initial; background-clip: initial; width: 640px; line-height: 20px; clear: both; border-left: 3px solid rgb(108, 226, 108);">// 通過字面量方式實現(xiàn)的函數(shù)eachvar 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, 所以不能直接調(diào)用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);});

輸出如下:

js,each,代碼

對象類型

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

輸出如下:

js,each,代碼

類數(shù)組類型

var ele = document.querySelectorAll('div');each(ele, function(i, v){ console.log(i + ': ' + v);});

輸出如下:

js,each,代碼

增加中斷條件

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,是個男的,不用關(guān)注了~'); return false; } console.log(i + ': ' + v);});

輸出如下:

js,each,代碼

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

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

另推薦個表格組件 gridManager 

總結(jié)

以上所述是小編給大家介紹的原生js實現(xiàn)each方法實例代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對VeVb武林網(wǎng)網(wǎng)站的支持!


注:相關(guān)教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 封丘县| 应城市| 铜川市| 潍坊市| 金乡县| 青川县| 沧源| 三亚市| 曲阜市| 韶山市| 保定市| 南通市| 栾川县| 海安县| 宁晋县| 麦盖提县| 耿马| 乐都县| 中卫市| 桐乡市| 策勒县| 海门市| 邵东县| 临高县| 永清县| 济宁市| 民县| 义马市| 会昌县| 金乡县| 高密市| 蓬莱市| 沅江市| 沛县| 宣威市| 确山县| 利津县| 罗定市| 南投县| 调兵山市| 汉寿县|