您好,登錄后才能下訂單哦!
本篇文章為大家展示了如何在Javascript中使用高級數組API,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
例一:偽數組,不能修改長短的數組(所以沒辦法清零),可以修改元素,代碼實現如下:
<script> fn(1,2); fn(1,2,3,4,5,6); fn(1,2,4,5,7,9,4); function fn(a,b){ arguments[0]=0; console.log(arguments); arguments.push(1); console.log(arguments instanceof Array); console.log(arguments.length);//實參個數 console.log(fn.length);//形參個數 console.log(arguments.callee);//整個函數,包括注釋 } </script>
偽數組打印的是實參,而普通函數調用打印的是形參,并且打印它的函數類型,我們發現它的類型顯示并不是數組。
例二:將一個字符串數組輸出為|分割的形式,比如“劉備|張飛|關羽”。使用兩種方式實現
方法一:不利用內置對象,進行字符串拼接,由于第一個元素前沒有特殊符號,首先將其賦值后,循環從下一個元素開始遍歷
<script> var arr=["劉備","張飛","關羽"]; var str=arr[0]; for(var i=1;i<arr.length;i++){ str+="|"+arr[i]; } console.log(str); </script>
方法二:使用內置對象直接改變間隔符號
<script> var arr=["劉備","張飛","關羽"]; var str=arr.join("|"); console.log(str); </script>
兩種方法進行對比,我們發現第一種方法使之產生了大量內存,導致內存浪費情況,從此看出對我們來說內置對象的使用幫我們解決了內存浪費的缺點。
例三:將一個字符串數組的元素的順序進行反轉。["a","b","c","d"] ->["d","c","b","a"]。使用兩種種方式實現。
方法一:之前文章介紹過的方法
<script> var str1=["a","b","c","d"]; var str2=[]; for(var i=0;i<str1.length;i++){ str2[str1.length-i-1]=str1[i]; } console.log(str2); </script>
方法二:直接使用內置對象reverse()
解決
<script> var str1=["a","b","c","d"]; console.log(str1.reverse()); </script>
例四:工資的數組[1500,1200,2000,2100,1800],把工資超過2000的刪除
使用內置對象filter()
實現題目需求。
<script> var arr=[1500,1200,2000,2100,1800]; var arr1=arr.filter(function(element,index,array){ if(element<=2000){ return true; } return false; }) console.log(arr1); </script>
例五:["c","a","z","a","x","a"]找到數組中每一個元素出現的次數
由于題目給出字符形式,讓我們求出的相應字符的個數為數字形式,這讓我們應用json更方便問題解決,將題目給出的字符作為“鍵”,將次數作為“鍵值”,來判斷數組中的元素,在json中是否存在屬性值,如果存在,在原有基礎上加上1;如果不存在直接賦值為1。
<script> var arr=["c","a","z","a","x","a"]; var json={}; for(var i=0;i<arr.length;i++){ if(json[arr[i]]!==undefined){ json[arr[i]]+=1; }else{ json[arr[i]]=1; } } console.log(json); </script>
例六:編寫一個方法 去掉一個數組的重復元素
方法一:新建數組,將原數組第一個元素push進入新數組。遍歷原數組的每一個元素使之在新數組每一個元素中都不存在(嵌套兩層for循環),就push進入原數組,否則就跳出新數組循環,進入原數組的下一個元素循環。
<script> var arr=[3,2,4,5,5,3,5,568,4,21,7]; var arr1=fn(arr); function fn(array){ var arr2=[]; arr2.push(array[0]); abc:for(var i=0;i<array.length;i++){ for(var j=0;j<arr2.length;j++){ if(arr2[j]==array[i]){ continue abc; } } arr2.push(array[i]); } return arr2; } console.log(arr1); </script>
方法二:創建一個新數組,循環遍歷,只要新數組中有舊數組的值,就不要在添加。每次都要判斷新數組中是否有舊數組的值,保證舊數組的元素和新數組中每一個都不相等,則賦值給新數組的下一元素的值。
<script> var arr=[1,2,3,4,5,2,3,4]; console.log(arr); console.log(fn(arr)); function fn(array){ var newArr=[]; for(var i=0;i<array.length;i++){ var bool=true; for(var j=0;j<newArr.length;j++){ if(array[i]===newArr[j]){ bool=false; } } if(bool){ newArr[newArr.length]=array[i]; } } return newArr; } </script>
1.JavaScript主要用來向HTML頁面添加交互行為。 2.JavaScript可以直接嵌入到HTML頁面,但寫成單獨的js文件有利于結構和行為的分離。 3.JavaScript具有跨平臺特性,在絕大多數瀏覽器的支持下,可以在多種平臺下運行。
上述內容就是如何在Javascript中使用高級數組API,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。