摘要:使用兩種方式實現劉備張飛關羽通過循環累加劉備張飛關羽可以把數組中的元素鏈接成字符串劉備張飛關羽將一個字符串數組的元素的順序進行反轉。
數組API
API: Application Programming Interface,應用程序編程接口;
js中對象提供的方法就叫做API;
instanceof檢測一個對象是否是數組;(用來對付復雜數據類型;) // 簡單數據類型 typeof ; A instanceof B // A是不是B造出來的; 例: var arr = [1,2,3]; console.log(arr instanceof Array); //arr屬不屬于Array類型;Array.isArray( )
Array.isArray(參數); // 判斷參數是不是數組,返回布爾值; 例: var arr = [1,2,3]; var num = 123; console.log(Array.isArray(arr)); //true console.log(Array.isArray(num)); //falsetoString( )
數組.toString(); // 把數組變成字符串,去除了[],內容用逗號鏈接; 例: var arr = ["aaa","bbb","ccc"]; console.log(arr.toString()); //返回 aaa,bbb,cccvalueOf( )
數組.valueOf(); //返回數組本身; 例: var arr = ["aaa","bbb","ccc"]; console.log(arr.valueOf()); //返回數組本身 ["aaa","bbb","ccc"]數組.join(參數)
數組.join(參數); // 數組中的元素可以按照參數進行鏈接變成一個字符串; console.log(arr.join()); //和toString()一樣用逗號鏈接 console.log(arr.join("|")); //用參數鏈接 console.log(arr.join("&")); //用參數鏈接 console.log(arr.join(" ")); //如果是空格,真的用空格鏈接 console.log(arr.join("")); //空字符是無縫連接數組元素的添加和刪除 push( )和pop( )
1. 數組.push() //在數組的最末尾添加元素; 2. 數組.pop() //不需要參數;在數組的最末尾刪除一項; 例: var arr = [1,2,3]; var aaa = arr.push("abc");//在數組的最末尾添加一個元素; console.log(arr);//元素被修改了 console.log(aaa);//返回值是數組的長度; aaa = arr.pop();//不需要參數;在數組的最末尾刪除一項; console.log(arr);//元素被修改了 console.log(aaa);//被刪除的那一項unshift( )和shift( )
1. 數組.unshift() //在數組的最前面添加一個元素; 2. 數組.shift() //不需要參數;在數組的最前面刪除一項; 例: var arr = [1,2,3]; aaa = arr.unshift("abc");//在數組的最前面添加一個元素; console.log(arr);//元素被修改了 console.log(aaa);//返回值是數組的長度; aaa = arr.shift();//不需要參數;在數組的最前面刪除一項; console.log(arr);//元素被修改了 console.log(aaa);//被刪除的那一項數組元素排序 reverse( )
reverse() //翻轉數組 例: var arr1 = [1,2,3,4,5]; var aaa = arr1.reverse(); // [5,4,3,2,1]sort( )
sort() // 數組中元素排序;(默認:從小到大) // 默認:按照首個字符的Unicode編碼排序;如果第一個相同那么就比較第二個... 例: var arr = [4,5,1,3,2,7,6]; var aaa =arr.sort(); console.log(aaa); // [1, 2, 3, 4, 5, 6, 7] console.log(aaa === arr);// true 原數組被排序了(冒泡排序) //默認還可以排列字母; var arr2 = ["c","e","d","a","b"]; var bbb = arr2.sort(); console.log(bbb); // ["a", "b", "c", "d", "e"] console.log(bbb===arr2); // true 原數組被排序了(冒泡排序) sort() //數值大小排序方法,需要借助回調函數; 例: var arr = [4,5,1,13,2,7,6]; //回調函數里面返回值如果是:參數1-參數2;升冪; 參數2-參數1;降冪; arr.sort(function (a,b) { return a-b; //升序 //return b-a; //降序 //return b.value-a.value; //按照元素value屬性的大小排序; }); console.log(arr); // [1, 2, 4, 5, 6, 7, 13]sort( )底層原理
var aaa = bubbleSort([1,12,3], function (a,b) { // return a-b;//實參:array[j]-array[j+1]; return b-a;//實參:array[j+1]-array[j]; }); console.log(aaa); function bubbleSort(array,fn){ //外循環控制輪數,內循環控制次數,都是元素個數-1; for(var i=0;i數組元素的操作 concat( )array[j+1]){//大于升冪排序;否則降冪; //a-b>0 和 a>b是一個意思; //b-a>0 和 a0){//升冪排序 // if(array[j+1]-array[j]>0){//降冪排序 //把兩個變量送到一個函數中; if(fn(array[j],array[j+1])>0){ var temp = array[j]; array[j] = array[j+1]; array[j+1] = temp; } } } //返回數組 return array; }
數組1.concat(數組2); // 鏈接兩個數組; var arr1 = [1,2,3]; var arr2 = ["a","b","c"]; var arr3 = arr1.concat(arr2); console.log(arr3) // [1, 2, 3, "a", "b", "c"]slice( )
數組.slice(開始索引值,結束索引值); //數組截取; 例 : var arr = [1, 2, 3, "a", "b", "c"]; console.log(arr.slice(3)); //從索引值為3截取到最后;["a", "b", "c"] console.log(arr.slice(0,3)); //包左不包右;[1, 2, 3] console.log(arr.slice(-2)); //負數是后幾個;["b", "c"] console.log(arr.slice(3,0)); //如果前面的比后面的大,那么就是[];[] console.log(arr); //原數組不被修改;[1, 2, 3, "a", "b", "c"]splice( )
數組.splice(開始索引值,刪除幾個,替換內容1,替換內容2,...); // 替換和刪除; //改變原數組;返回值是被刪除/替換的內容 例: var arr = [1,2,3,4,5,6,"a", "b", "c"] arr.splice(5); //從索引值為3截取到最后;(刪除) console.log(arr); // [1, 2, 3, 4, 5] arr.splice(1,2); //(刪除指定個數)從索引為1的開始刪除2個 console.log(arr); //[1, 4, 5] //替換 var arr = [1,2,3,4,5,6,"a", "b", "c"]; console.log(arr.splice(3,3,"aaa","bbb","ccc")); //(刪除指定數并替換) console.log(arr); // [1, 2, 3, "aaa", "bbb", "ccc", "a", "b", "c"] // 添加 arr.splice(3,0,"aaa","bbb","ccc");//(刪除指定個數) // console.log(arr);//截取或者替換之后的; [1, 2, 3, "aaa", "bbb", "ccc", "aaa", "bbb", "ccc", "a", "b", "c"]indexOf / lastIndexOf
數組.indexOf(元素); // 給元素,查索引(從前往后) 數組.lastIndexOf(元素); // 給元素,查索引(從后往前) 例: var arr = ["a","b","c","d","c","b","b"]; console.log(arr.indexOf("b")); // 1 查到以后立刻返回 console.log(arr.lastIndexOf("b")); // 6 找到以后立刻返回 console.log(arr.indexOf("xxx")); // -1; 查不到就返回-1;數組迭代(遍歷) every()
對數組中每一項運行回調函數,如果都返回true,every返回true, 如果有一項返回false,則停止遍歷 every返回false;不寫默認返回false 像保鏢失誤一次,游戲結束!!! 例: 1. var arr = [111,222,333,444,555]; arr.every(function (a,b,c) { console.log(a); //元素 console.log(b); //索引值 console.log(c); //數組本身; console.log("-----"); //數組本身; //數組中元素賦值:c[b] = 值; a=有時候無法賦值; return true; }); 2. //every返回一個bool值,全部是true才是true;有一個是false,結果就是false var bool = arr.every(function (element, index, array) { //判斷:我們定義所有元素都大于200; //if(element > 100){ if(element > 200){ return true; }else{ return false; } }) alert(bool); //falsefilter()
// 對數組中每一項運行回調函數,該函數返回結果是true的項組成的新數組 // 新數組是有老數組中的元素組成的,return為ture的項; 例: var arr = [111,222,333,444,555]; var newArr = arr.filter(function (element, index, array) { //只要是奇數,就組成數組;(數組中辨別元素) if(element%2 === 0){ return true; }else{ return false; } }) console.log(newArr); // [222, 444]forEach()
// 和for循環一樣;沒有返回值; 例: var arr = [111,222,333,444,555]; var sum = 0; var aaa = arr.forEach(function (element,index,array) { console.log(element); // 輸出數組中的每一個元素 console.log(index); // 數組元素對應的索引值 console.log(array); // 數組本身 [111, 222, 333, 444, 555] sum += element; //數組中元素求和; }); console.log(sum); // 數組元素加起來的和 console.log(aaa);//undefined;沒有返回值 所以返回undefinedmap()
// 對數組中每一項運行回調函數,返回該函數的結果組成的新數組 // return什么新數組中就有什么; 不return返回undefined; 對數組二次加工 例: var arr = [111,222,333,444,555]; var newArr = arr.map(function (element, index, array) { if(index == 2){ return element; // 這里return了 所以下面返回的值是333 } return element*100; // 返回的元素值都乘上100后的值 }) console.log(newArr); // [11100, 22200, 333, 44400, 55500]some()
//對數組中每一項運行回調函數,如果該函數對某一項返回true,則some返回true; 像殺手,有一個成功,就勝利了!!! 例: var arr = [111,222,333,444,555]; var bool = arr.some(function (ele,i,array) { //判斷:數組中有3的倍數 if(ele%3 == 0){ return true; } return false; }) alert(bool); //true ; 有一個成功就是true數組清空
1. arr.length = 0; // (不好,偽數組無法清空) 2. arr.splice(0); // 偽數組沒有這個方法; 3. arr = []; // 可以操作偽數組; (推薦!)
// 偽數組: 就是長的像數組,但是沒有數組的方法;也不能添加和刪除元素; 例: // arguments fn(111,222,333); function fn(){ arguments.length = 0; // 無法清空 返回 [1, 2, 3] arguments.splice(0); // 會報錯 arguments.splice is not a function arguments = []; // 可以清空,返回空數組[] console.log(arguments); }數組案例
1.將一個字符串數組輸出為|分割的形式,比如“劉備|張飛|關羽”。使用兩種方式實現
var arr = ["劉備","張飛","關羽"]; var separator = "|"; //通過for循環累加 var str = arr[0]; for(var i=1;i2.將一個字符串數組的元素的順序進行反轉。["a", "b", "c", "d"] -> [ "d","c","b","a"]。使用兩種種方式實現。提示:第i個和第length-i-1個進行交換
// 數組.reverse() 方法 var arr = ["a", "b", "c", "d"]; console.log(arr.reverse()); // ["d", "c", "b", "a"] // 三種:1.正向遍歷,反向添加; 2.反向遍歷,正向添加; 3.元數組元素交換位置; for(var i=0;i3.工資的數組[1500, 1200, 2000, 2100, 1800],把工資超過2000的刪除
var arr = [1500, 1200, 2000, 2100, 1800]; //利用filter()形成一個數組;return true;組成的數組; var newArr = arr.filter(function (ele, i, array) { //2000以上返回false; if(ele<2000){ return true; }else{ return false; } }); console.log(newArr); // [1500, 1200, 1800]4.["c", "a", "z", "a", "x", "a"]找到數組中每一個a出現的位置
var arr = ["c", "a", "z", "a", "x", "a"]; //遍歷數組(for/while/do...while) forEach(); arr.forEach(function (ele, index, array) { //如果元素等于“a”,那么就輸出索引值; if("a" === ele){ console.log(index); } });5.編寫一個方法去掉一個數組的重復元素 (數組去重)
var arr = ["鳴人","鳴人","佐助","佐助","小櫻","小櫻"]; // 方法1: 思路:定義一個新數組,遍歷老數組,判斷,如果新數組里面沒有老數組的元素就添加,否則就不添加; var newArr = []; //遍歷老數組 arr.forEach(function (ele,index,array) { //檢測老數組中的元素,如果新數組中存在就不添加了,不存在才添加; if(newArr.indexOf(ele) === -1){//不存在就添加;(去新數組中查找元素索引值,如果為-1就是沒有) newArr.push(ele); } }); console.log(newArr); // ["鳴人", "佐助", "小櫻"] 也可以利用ES6中的Set方法達到快速去重,一行代碼解決: [...new Set(arr)] 或者:Array.from(new Set(arr)) // ["鳴人", "佐助", "小櫻"]
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/90173.html
摘要:函數的因為也擁有屬性,所以其被稱為類數組對象。方法數組的拼接,,指被拼接的對象數組,為數組。如果為負,則將其視為,其中為數組的長度。而提供了數組反轉和排序來對數組進行重排序。用好原生,你的代碼將顯得干凈,有趣。 前言 最近工作做數據交互展示,常和數據打交道,而隨之而來的就是遇見后端傳來的各種各樣的數組,我需要用各式各樣的方法來變換這些數據,來最好的展示這些數據;很多東西久了沒用就容易忘...
摘要:語法數組刪除數組的最后一項語法數組在數組的最末添加一項語法數組刪除數組的首項語法數組在數組的首部添加一項案例分析 1:數組的指針操作: 語法:current(數組) 當前指針指向的單元值(默認是第零個)語法 next(數組) 當前指針往下移動一幀語法 prev(數組) 當前指針往前移動一個指針語法 end(array) 將當前指針移動到最后一項語法 ...
摘要:在中,數組里可以容納容納中任何類型的值。方法大全在中數組是可修改的對象,每個數組都有著很多好用的方法,大多數我們日常都會常用。把元素添加到數組的頭部。利用使用下標進行操作。對當前數組中的每一項運行給定的函數返回函數結果為的項組成的數組。 雜談 ????數組是最簡單的內存數據結構,也是js中最常用的類型之一,整理了下我覺得應該了解數組的相關知識。 在js中,數組里可以容納容納js中任何...
摘要:類型化數組也是中新引入的。用一句話解釋類型化數組就是它是操作二進制數據的接口。類型化數組類型化數組的應用二進制數據的接口主要應用于文件,在中涉及文件處理的幾乎都可以應用,主要是,,。 類型化數組(Typed Array)也是HTML5中新引入的API。用一句話解釋類型化數組就是:它是JS操作二進制數據的接口。 眾所周知,直接操作二進制數據可以使程序更為高效, 盡管JS對常規數組做了很多...
摘要:只有滿足才返回,否則返回。專門用于篩選出數組中符合函數判斷條件的元素組成的心數組。專門用于對原數組中每個元素執行相同的函數對象規定的操作。并歸方法將數組從左向右迭代。 Array類型 數組的常見方法 檢測數組 如何確定當前是一個數組,JS提供了以下幾種方式1.typeof無法檢測數組對象:typrof[]返回object2.instanceof:[]instanceof Array返回...
摘要:基本操作數組去重數組去重的方法臨時數組保存其實這里面還沒考慮到數組里面嵌套數組對象的情況把去重后的結果放在一個臨時數組中對原來數組的元素與臨時數組元素比較臨時數組中不存在這個元素的放入臨時數組。 js基本操作-數組去重 數組去重的方法 1. 臨時數組保存(其實這里面還沒考慮到數組里面嵌套數組/對象的情況) 把去重后的結果放在一個臨時數組中, 對原來數組的元素與臨時數組元素比較, 臨時...
閱讀 1384·2021-11-15 18:11
閱讀 2512·2021-08-19 10:56
閱讀 680·2021-08-09 13:42
閱讀 795·2019-08-30 15:53
閱讀 2088·2019-08-30 10:55
閱讀 3144·2019-08-29 17:18
閱讀 1437·2019-08-29 13:45
閱讀 546·2019-08-29 13:15