摘要:的數(shù)組對象中有很多有用的方法,的函數(shù)在某些方面非常的方便強大。函數(shù)的使用例子求數(shù)組中每個元素的平方根的值為的值仍為應用下面代碼展示了如何去遍歷用得到的動態(tài)對象集合。
js的Array數(shù)組對象中有很多有用的方法,js的map函數(shù)在某些方面非常的方便強大。
map() 方法創(chuàng)建一個新數(shù)組,其結果是該數(shù)組中的每個元素都調用一個提供的函數(shù)后返回的結果。
let numbers = [1, 5, 10, 15]; let roots = numbers.map((x) => { return x * 2; }); let roots = numbers.map( x => x * 2); // roots is now [2, 10, 20, 30] // numbers is still [1, 5, 10, 15] let numbers = [1, 4, 9]; // let roots = numbers.map(Math.sqrt); let roots = numbers.map(function(x){ return Math.sqrt(x); }); // roots is now [1, 2, 3] // numbers is still [1, 4, 9]map函數(shù)的使用例子 求數(shù)組中每個元素的平方根
var numbers = [1, 4, 9]; var roots = numbers.map(Math.sqrt); /* roots的值為[1, 2, 3], numbers的值仍為[1, 4, 9] */querySelectorAll 應用
下面代碼展示了如何去遍歷用 querySelectorAll 得到的動態(tài)對象集合。在這里,我們獲得了文檔里所有選中的選項,并將其打印:
var elems = document.querySelectorAll("select option:checked"); var values = Array.prototype.map.call(elems, function(obj) { return obj.value; });反轉字符串
var str = "12345"; Array.prototype.map.call(str, function(x) { return x; }).reverse().join(""); // Output: "54321" // Bonus: use "===" to test if original string was a palindrome兼容舊環(huán)境
// 實現(xiàn) ECMA-262, Edition 5, 15.4.4.19 // 參考: http://es5.github.com/#x15.4.4.19 if (!Array.prototype.map) { Array.prototype.map = function(callback, thisArg) { var T, A, k; if (this == null) { throw new TypeError(" this is null or not defined"); } // 1. 將O賦值為調用map方法的數(shù)組. var O = Object(this); // 2.將len賦值為數(shù)組O的長度. var len = O.length >>> 0; // 3.如果callback不是函數(shù),則拋出TypeError異常. if (Object.prototype.toString.call(callback) != "[object Function]") { throw new TypeError(callback + " is not a function"); } // 4. 如果參數(shù)thisArg有值,則將T賦值為thisArg;否則T為undefined. if (thisArg) { T = thisArg; } // 5. 創(chuàng)建新數(shù)組A,長度為原數(shù)組O長度len A = new Array(len); // 6. 將k賦值為0 k = 0; // 7. 當 k < len 時,執(zhí)行循環(huán). while(k < len) { var kValue, mappedValue; //遍歷O,k為原數(shù)組索引 if (k in O) { //kValue為索引k對應的值. kValue = O[ k ]; // 執(zhí)行callback,this指向T,參數(shù)有三個.分別是kValue:值,k:索引,O:原數(shù)組. mappedValue = callback.call(T, kValue, k, O); // 返回值添加到新數(shù)組A中. A[ k ] = mappedValue; } // k自增1 k++; } // 8. 返回新數(shù)組A return A; }; }
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/87082.html
摘要:函數(shù)式編程函數(shù)式,可能并不是那么難。在學習函數(shù)式編程之初,首先要知道在這一技能葉子中包含有多少個相關詞,其次要知道它和我們是否從未有過遇見。 JS函數(shù)式編程 函數(shù)式,可能并不是那么難。 在學習JS函數(shù)式編程之初,首先要知道在這一技能葉子中包含有多少個相關詞,其次要知道它和我們是否從未有過遇見。 一等公民、純函數(shù)、柯里化、代碼組合、pointfree、命令式與申明式、 Hindley...
摘要:本文是響應式編程第二章序列的深入研究這篇文章的學習筆記。函數(shù)科里化的基本應用,也是函數(shù)式編程中運算管道構建的基本方法。四資料參考函數(shù)式編程指南 本文是Rxjs 響應式編程-第二章:序列的深入研究這篇文章的學習筆記。示例代碼托管在:http://www.github.com/dashnowords/blogs 更多博文:《大史住在大前端》目錄 showImg(https://segme...
摘要:但是有了尾調用優(yōu)化之后,遞歸函數(shù)的性能有了提升。常被用來檢查對象中是否存在某個鍵名,集合常被用來獲取已存的信息。循環(huán)解構對象本身不支持迭代,但是我們可以自己添加一個生成器,返回一個,的迭代器,然后使用循環(huán)解構和。 一、let和const 在JavaScript中咱們以前主要用關鍵var來定義變量,ES6之后,新增了定義變量的兩個關鍵字,分別是let和const。對于變量來說,在ES5中...
摘要:真正留給我們要實現(xiàn)的僅僅是返回另外一部分用于局部應用的一元函數(shù)罷了。總結各用一句話做個小結吧局部應用是一種轉換技巧,通過預先傳入一個或多個參數(shù)來把多元函數(shù)轉變?yōu)楦僖恍┰暮瘮?shù)甚或是一元函數(shù)。 局部應用(Partial Application,也譯作偏應用或部分應用)和局部 套用( Currying, 也譯作柯里化),是函數(shù)式編程范式中很常用的技巧。 本文著重于闡述它們的...
摘要:函數(shù)式編程一般約定,函子有一個方法,用來生成新的容器。是實現(xiàn)了函數(shù)并遵守一些特定規(guī)則的容器類型。定義二若為廣群,且運算還滿足結合律,即任意,有,則稱為半群。 slide 地址 四、Talk is cheap!Show me the ... MONEY! 以下內容主要參考自 Professor Frisby Introduces Composable Functional JavaScr...
閱讀 3491·2021-11-18 10:02
閱讀 1620·2021-10-12 10:12
閱讀 3001·2021-10-09 09:53
閱讀 4893·2021-09-09 09:34
閱讀 875·2021-09-06 15:02
閱讀 2785·2021-08-05 10:02
閱讀 3146·2019-08-30 15:44
閱讀 3129·2019-08-28 18:04