溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

怎么使用js查找數(shù)組中符合條件的元素

發(fā)布時(shí)間:2023-05-09 15:40:03 來(lái)源:億速云 閱讀:130 作者:iii 欄目:開(kāi)發(fā)技術(shù)

今天小編給大家分享一下怎么使用js查找數(shù)組中符合條件的元素的相關(guān)知識(shí)點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識(shí),所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來(lái)了解一下吧。

一、利用for循環(huán)進(jìn)行查找

let arr = [
  {name: 'zhangsan', age: 18},
  {name: 'lisi', age: 17},
  {name: 'xiaoming', age: 18},
],
result = []
for (let item of arr){
  if(item.age === 18){
    result.push(item);
  }
}
console.log(result);// [{name: 'zhangsan', age: 18},{name: 'xiaoming', age: 18}]

二、filter() 方法

注意:

filter() 方法創(chuàng)建一個(gè)新的數(shù)組,新數(shù)組中的元素是通過(guò)檢查指定數(shù)組中符合條件的所有元素。

filter() 不會(huì)對(duì)空數(shù)組進(jìn)行檢測(cè)。

filter() 不會(huì)改變?cè)紨?shù)組。

let arr = [
  {name: 'zhangsan', age: 18},
  {name: 'lisi', age: 17},
  {name: 'xiaoming', age: 18},
];
let result = arr.filter(item=>item.age === 18)
console.log(result);// [{name: 'zhangsan', age: 18},{name: 'xiaoming', age: 18}]

三、find()方法

注意:

find()方法只返回?cái)?shù)組中滿足條件的第一個(gè)元素,并非所有元素

當(dāng)數(shù)組中的元素在條件返回 true 時(shí), find() 返回符合條件的元素,之后的值不會(huì)再調(diào)用執(zhí)行函數(shù)。

如果沒(méi)有符合條件的元素返回 undefined

find() 對(duì)于空數(shù)組,函數(shù)是不會(huì)執(zhí)行的。

find() 并沒(méi)有改變數(shù)組的原始值。

let arr = [
  {name: 'zhangsan', age: 18},
  {name: 'lisi', age: 17},
  {name: 'xiaoming', age: 18},
];
let result = arr.find(item=>item.age === 18)
console.log(result);// {name: 'zhangsan', age: 18}

附:JavaScript查找一個(gè)數(shù)組中符合某個(gè)條件的值,并將符合條件的值存入新的數(shù)組

1. 利用find函數(shù)和es6箭頭函數(shù),下面方法取到數(shù)組中滿足條件的第一個(gè)元素;

var newArray  = {};//新對(duì)象
var array = [
 {name:'aiai',age:18},
 {name:'sisi',age:18},
 {name:'lulu',age:18},
 {name:'sisi',age:19}
]; 
//查找符合條件值并存入新數(shù)組
newArrar = this.array.find((item) => {
   if(item.name === 'sisi'){
     return item
   }
 })
//此時(shí) newArray = {name:'sisi',age:18}

2. 查找符合條件的所有元素

var newArray  = [];//新數(shù)組
var j = 0;
var array = [
 {name:'aiai',age:18},
 {name:'sisi',age:18},
 {name:'lulu',age:18},
 {name:'sisi',age:19}
]; //目標(biāo)數(shù)組
 
//查找符合條件值并存入新數(shù)組
for(let i in array){
 if(array[i].name == 'sisi'){
  newArray[j++] = array[i]
 }
}
//此時(shí) newArray = [{name:'sisi',age:18},{name:'sisi',age:19}]

以上就是“怎么使用js查找數(shù)組中符合條件的元素”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會(huì)為大家更新不同的知識(shí),如果還想學(xué)習(xí)更多的知識(shí),請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

js
AI