Array對象常用屬性

来源:https://www.cnblogs.com/yyjbk/archive/2018/10/10/9764518.html
-Advertisement-
Play Games

concat() 用於連接兩個或多個數組。該方法不會改變現有的數組,而僅僅會返回被連接數組的一個副本。 every() 用於檢測數組所有元素是否都符合指定條件(通過函數提供)。 every() 方法使用指定函數檢測數組中的所有元素: 如果數組中檢測到有一個元素不滿足,則整個表達式返回 false , ...


concat() 

用於連接兩個或多個數組。該方法不會改變現有的數組,而僅僅會返回被連接數組的一個副本。

var a = ["aa","ccc"];
var b = ["vv","mm"];
var c = ["123"];
var d = a.contac(b,c);  ==> ["aa","ccc","vv","mm","123"]

every()

用於檢測數組所有元素是否都符合指定條件(通過函數提供)。

  every() 方法使用指定函數檢測數組中的所有元素:

  • 如果數組中檢測到有一個元素不滿足,則整個表達式返回 false ,且剩餘的元素不會再進行檢測。
  • 如果所有元素都滿足條件,則返回 true。

      註意: every() 不會對空數組進行檢測。

      註意: every() 不會改變原始數組。

var ary = [3,4,5,6,7]
var result = ary.every(function(item){
    return item>5;          
}) ==> false

filter()

創建一個新的數組,新數組中的元素是通過檢查指定數組中符合條件的所有元素。

  註意: filter() 不會對空數組進行檢測。

  註意: filter() 不會改變原始數組。

var ary = [2,3,5,6,7];
var result = ary.filter(function(item){
    return item>3;
}); ==> [5,6,7]

forEach()

用於調用數組的每個元素,並將元素傳遞給回調函數。

var ary = [3,4,5,6,7]
var result = ary.forEach(function(item,index){
   console.log(item,index)         
});

 includes()

用來判斷一個數組是否包含一個指定的值,如果是返回 true,否則false。

arr.includes(searchElement)
arr.includes(searchElement, fromIndex)
// searchElement   要查找的元素
// fromIndex       從該索引處開始查找 searchElement。如果fromIndex 大於等於數組長度 ,則返回 false ,該數組不會被搜索
           如果為負值,則按升序從 array.length + fromIndex 的索引開始搜索。預設為 0。如果計算出的索引小於 0,則整個數組都會被搜索。
var arr = ['a', 'b', 'c'];
arr.includes('a'); // true
arr.includes('a', -100); // true

indexOf()

可返回數組中某個指定的元素位置。如果在數組中沒找到指定元素則返回 -1。

var num = [1,2,3,4,'Apple'];
var a = num.indexOf("Apple");  //4

lastIndexOf()

可返回一個指定的元素在數組中最後出現的位置,在一個數組中的指定位置從後向前搜索。如果要檢索的元素沒有出現,則該方法返回 -1。

var num = [1,2,3,4,'Apple'];
var a = num.lastIndexOf("Apple");  //4

isArray()

用於判斷一個對象是否為數組。如果對象是數組返回 true,否則返回 false。

var item = [];
Array.isArray(item);  //true

join()

用於把數組中的所有元素轉換一個字元串。元素是通過指定的分隔符進行分隔的。

var fruits = ["Banana", "Orange", "Apple", "Mango"];
var energy = fruits.join();  //Banana,Orange,Apple,Mango
var energy = fruits.join("|");  //Banana|Orange|Apple|Mango

map()

返回一個新數組,數組中的元素為原始數組元素調用函數處理後的值。

  map() 方法按照原始數組元素順序依次處理元素。

  註意: map() 不會對空數組進行檢測。

  註意: map() 不會改變原始數組。

var ary= [4,9,16,25];
var result = ary.map(Math.sqrt); //求平方根:result ==> 2,3,4,5

pop()

用於刪除數組的最後一個元素並返回刪除的元素。註意:此方法改變原數組長度。

var ary = [2,4,5,6];
var del = ary.pop(); //del ==> 6
// ary ==> 2,4,5

push()

可向數組的末尾添加一個或多個元素,並返回新的長度。註意:此方法改變原數組長度。

var ary = ['aa','bb','cc'];
var result = ary.push('ss');  //result ==> 4
//ary ==> ['aa','bb','cc','ss']

shift()

用於刪除並返回數組的第一個元素。註意:此方法改變原數組長度。

var ary = [2,4,5,6];
var del = ary.shift(); //del ==> 2 
// ary ==> 4,5,6

unshift()

可向數組的開頭添加一個或更多元素,並返回新的長度。註意:此方法改變原數組長度。

var ary = ['aa','bb','cc'];
var result = ary.unshift('ss');  //result ==> 4
//ary ==> ['ss','aa','bb','cc']

reduce()

接收一個函數作為累加器,數組中的每個值(從左到右)開始縮減,最終計算為一個值。

  這個函數必須接收兩個參數,reduce()把結果繼續和序列的下一個元素做累積計算。

  註意: reduce() 對於空數組是不會執行回調函數的。

var arr = [1, 3, 5, 7, 9];
arr.reduce(function (x, y) {
    return x + y;
}); // 25

reduceRight() 方法的功能和 reduce() 功能是一樣的,不同的是 reduceRight() 從數組的末尾向前將數組中的數組項做累加。

reverse()

用於顛倒數組中元素的順序。

var fruits = [1, 2, 3, 4];
fruits.reverse();  // [4,3,2,1]

slice()

可從已有的數組中返回選定的元素。

  slice()方法可提取字元串的某個部分,並以新的字元串返回被提取的部分。

  註意: slice() 方法不會改變原始數組。

返回一個新的數組,包含從 start 到 end (不包括該元素)的 arrayObject 中的元素。

array.slice(start, end)
//start 可選。規定從何處開始選取。如果是負數,那麼它規定從數組尾部開始算起的位置。
//end 可選。規定從何處結束選取。
//該參數是數組片斷結束處的數組下標。如果沒有指定該參數,那麼切分的數組包含從 start 到數組結束的所有元素。
//如果這個參數是負數,那麼它規定的是從數組尾部開始算起的元素。
var fruits = ["Banana", "Orange", "Lemon", "Apple", "Mango"];
var citrus = fruits.slice(1,3);   // ["Orange", "Lemon"]

some()

用於檢測數組中的元素是否滿足指定條件(函數提供)。

some() 方法會依次執行數組的每個元素:

  • 如果有一個元素滿足條件,則表達式返回true , 剩餘的元素不會再執行檢測。
  • 如果沒有滿足條件的元素,則返回false。
var arr = [1, 3, 5, 7, 9];
arr.some(function (item) {
    return item>4;
}); // true

sort()

用於對數組的元素進行排序。返回新的數組

  排序順序可以是字母或數字,並按升序或降序。預設排序順序為按字母升序。

  註意:當數字是按字母順序排列時"40"將排在"5"前面。

  使用數字排序,你必須通過一個函數作為參數來調用。

  函數指定數字是按照升序還是降序排列。

  註意: 這種方法會改變原始數組!

var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.sort();   // Apple,Banana,Mango,Orange

//升序
var points = [40,100,1,5,25,10];
points.sort(function(a,b){return a-b});  //1,5,10,25,40,100

//降序
var points = [40,100,1,5,25,10];
points.sort(function(a,b){return b-a});  // 100,40,25,10,5,1

splice()

用於插入、刪除或替換數組的元素。

  註意:這種方法會改變原始數組!

array.splice(index,howmany,item1,.....,itemX)
//index 必需。規定從何處添加/刪除元素。該參數是開始插入和(或)刪除的數組元素的下標,必須是數字。
//howmany      必需。規定應該刪除多少元素。必須是數字,但可以是 "0"。如果未規定此參數,則刪除從 index 開始到原數組結尾的所有元素。
//item1, ..., itemX  可選。要添加到數組的新元素

//如果從 arrayObject 中刪除了元素,則返回的是含有被刪除的元素的數組。
//移除數組的第三個元素,併在數組第三個位置添加新元素:
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.splice(2,1,"Lemon","Kiwi"); //["Banana", "Orange", "Lemon","Kiwi","Mango"]

//從第三個位置開始刪除數組後的兩個元素:
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.splice(2,2);  //["Banana", "Orange"]

toString()

可把數組轉換為字元串,並返回結果。

註意: 數組中的元素之間用逗號分隔。

array.toString()

valueOf()

返回 Array 對象的原始值。

  該原始值由 Array 對象派生的所有對象繼承。

  valueOf() 方法通常由 JavaScript 在後臺自動調用,並不顯式地出現在代碼中。

  註意: valueOf() 方法不會改變原數組。

//valueOf() 是數組對象的預設方法。
// fruits.valueOf()與 fruits返回值一樣。
var fruits = ["Banana", "Orange", "Apple", "Mango"];
var v=fruits.valueOf(); 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本文介紹了無法通過fastboot擦除misc分區時,利用QFIL工具退出FFBM的詳細步驟。 ...
  • 一、屏蔽系統簡訊功能 1、屏蔽所有簡訊 android 4.2 簡訊發送流程分析可參考這篇 [戳這][1] 源碼位置 vendor\mediatek\proprietary\packages\apps\Mms\src\com\android\mms\transaction\SmsReceiverSe ...
  • 歡迎大家前往 "騰訊雲+社區" ,獲取更多騰訊海量技術實踐乾貨哦~ 本文由 "QQ音樂技術團隊" 發表於 "雲+社區專欄" 一、問題背景與分析 不久前,團隊發現其Android平臺App在播放MV視頻《鳳凰花開的路口》時,會帶有如電流聲一般的雜音,這影響了用戶體驗。 研發同學在初步定位時,發現有如下 ...
  • 歡迎大家前往 "騰訊雲+社區" ,獲取更多騰訊海量技術實踐乾貨哦~ 本文由 "QQ音樂技術團隊" 發表於 "雲+社區專欄" 上篇:Android P 行為變更適配 Android P 這次有很多行為變更,其中不乏一些需要亟需適配的變更。 一、全面屏檢測 在 Android 8.0 時代各個手機廠商就 ...
  • 測試內容 ...
  • 1、清除浮動的相容性(低版本的瀏覽器不相容問題) .clearfix:after{ content:""; clear:both; display:block; visibility:hidden; height:0; } .clear{ *zoom:1; } 2、透明度的相容性 opacity:0 ...
  • 如今Webpack已經是一個不可或缺的前端構建工具,藉助這個構建工具,我們可以使用比較新的技術(瀏覽器不能直接支持)來開發。 你是否好奇你寫的代碼經過Webpack構建之後會生成什麼東西?是否有時調試遇到莫名其妙的問題? 本文不講如何進行配置,只是基於幾個基礎的例子,簡要分析一下 webpack@4 ...
  • 教程所示圖片使用的是 github 倉庫圖片,網速過慢的朋友請移步 "《webpack4 系列教程(十一):字體文件處理》原文地址" 。或者來我的小站看更多內容: "godbmw.com" 0. 課程介紹和資料 " 本節課源碼" " 所有課程源碼" 本節課的代碼目錄如下: 本節課的 內容如下: 1. ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...