JS中的forEach、$.each、map方法推薦
forEach是ECMA5中Array新方法中最基本的一個(gè),就是遍歷,循環(huán)。例如下面這個(gè)例子:
[1, 2 ,3, 4].forEach(alert);
等同于下面這個(gè)for循環(huán)
var array = [1, 2, 3, 4]; for (var k = 0, length = array.length; k < length; k++) { alert(array[k]); }
Array在ES5新增的方法中,參數(shù)都是function類型,默認(rèn)有傳參,forEach方法中的function回調(diào)支持3個(gè)參數(shù),第1個(gè)是遍歷的數(shù)組內(nèi)容;第2個(gè)是對(duì)應(yīng)的數(shù)組索引,第3個(gè)是數(shù)組本身。
因此,我們有:
[].forEach(function(value, index, array) { // ... });
對(duì)比jQuery中的$.each方法:
$.each([], function(index, value, array) { // ... });
會(huì)發(fā)現(xiàn),第1個(gè)和第2個(gè)參數(shù)正好是相反的,大家要注意了,不要記錯(cuò)了。后面類似的方法,例如$.map也是如此。
var data=[1,3,4] ; var sum=0 ; data.forEach(function(val,index,arr){ console.log(arr[index]==val); // ==> true sum+=val }) console.log(sum); // ==> 8
map
這里的map不是“地圖”的意思,而是指“映射”。[].map(); 基本用法跟forEach方法類似:
array.map(callback,[ thisObject]);
callback的參數(shù)也類似:
[].map(function(value, index, array) { // ... });
map方法的作用不難理解,“映射”嘛,也就是原數(shù)組被“映射”成對(duì)應(yīng)新數(shù)組。下面這個(gè)例子是數(shù)值項(xiàng)求平方:
var data=[1,3,4] var Squares=data.map(function(val,index,arr){ console.log(arr[index]==val); // ==> true return val*val }) console.log(Squares); // ==> [1, 9, 16]
注意:由于forEach、map都是ECMA5新增數(shù)組的方法,所以ie9以下的瀏覽器還不支持(萬惡的IE?。?,不過呢,可以從Array原型擴(kuò)展可以實(shí)現(xiàn)以上全部功能,例如forEach方法:
if (typeof Array.prototype.forEach != "function") { Array.prototype.forEach = function() { /* 實(shí)現(xiàn) */ }; }
以上這篇JS中的forEach、$.each、map方法推薦就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
js實(shí)現(xiàn)獲取兩個(gè)日期之間所有日期的方法
這篇文章主要介紹了js實(shí)現(xiàn)獲取兩個(gè)日期之間所有日期的方法,涉及javascript針對(duì)日期與時(shí)間的相關(guān)操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2016-06-06JavaScript基于對(duì)象去除數(shù)組重復(fù)項(xiàng)的方法
這篇文章主要介紹了JavaScript基于對(duì)象去除數(shù)組重復(fù)項(xiàng)的方法,結(jié)合實(shí)例形式分析了javascript數(shù)組去重的操作步驟與具體實(shí)現(xiàn)技巧,需要的朋友可以參考下2016-10-10原生JS實(shí)現(xiàn)的簡單輪播圖功能【適合新手】
這篇文章主要介紹了原生JS實(shí)現(xiàn)的簡單輪播圖功能,結(jié)合實(shí)例形式分析了基于javascript定時(shí)器控制頁面元素動(dòng)態(tài)變換實(shí)現(xiàn)輪播圖的相關(guān)操作技巧,需要的朋友可以參考下2018-08-08JS項(xiàng)目中對(duì)本地存儲(chǔ)進(jìn)行二次的封裝的實(shí)現(xiàn)
這篇文章主要介紹了JS項(xiàng)目中對(duì)本地存儲(chǔ)進(jìn)行二次的封裝,這里我們將要使用到的key存儲(chǔ)下來,新建一個(gè)叫constant-storage.js的文件,對(duì)外暴露一些key的鍵名,也方便后期統(tǒng)一修改,這里因?yàn)槎际呛懔?,所以名稱我們都用大寫表示,需要的朋友可以參考下2022-07-07Javascript實(shí)現(xiàn)仿WebQQ界面的“浮云”兼容 IE7以上版本及FF
兼容:IE7以上版本及FF;(騰訊的WebQQ3.0好像也不兼容IE6,其實(shí)這樣挺好的)2011-04-04