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