91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

原生js實現each方法實例代碼詳解

發布時間:2020-10-02 19:35:20 來源:腳本之家 閱讀:136 作者:mrr 欄目:web開發

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

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

簡單實現:

// 通過字面量方式實現的函數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;
  }
 })();
 // 為數組或類數組時, 返回: index, value
 if(type === 'Array' || type === 'NodeList'){
  // 由于存在類數組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一下, 測試下數組、對象、類數組類型及中斷效果

數組類型

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方法實例代碼詳解 

類數組類型

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的屬性時,則輸出警告,用于實現continue效果
 console.log('存在鍵值為age,這家伙已經'+v+'歲了');
 return true;
 }
 if(i === 'six' && v === '男'){//如果存在鍵值為age的屬性時,則輸出跳出,用于實現break效果
 console.log('存在鍵值為six,是個男的,不用關注了~');
 return false;
 }
 console.log(i + ': ' + v);
});

輸出如下:

原生js實現each方法實例代碼詳解 

從結果可以看出來,each方法已經實現了jquery的each功能。且實現如此簡單~

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

另推薦個表格組件 gridManager

總結

以上所述是小編給大家介紹的原生js實現each方法實例代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

镇平县| 尖扎县| 富宁县| 牙克石市| 元谋县| 临泽县| 区。| 公安县| 平乐县| 苏尼特右旗| 五华县| 尉氏县| 呼和浩特市| 康定县| 阿拉善左旗| 泗洪县| 桓仁| 泗水县| 旬邑县| 天柱县| 高尔夫| 南京市| 富顺县| 龙陵县| 富民县| 兰州市| 酉阳| 达孜县| 武邑县| 木兰县| 兴国县| 砀山县| 阜南县| 巴彦淖尔市| 阿拉善左旗| 深泽县| 沙雅县| 清新县| 化隆| 林州市| 游戏|