亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何匹配對象的多個屬性

如何匹配對象的多個屬性

皈依舞 2022-10-13 19:28:04
我可以很容易地匹配一個屬性var peoples = [  { "name": "bob", "dinner": "pizza" },  { "name": "john", "dinner": "sushi" },  { "name": "larry", "dinner": "hummus" },  { "name": "john", "dinner": "pie" }];$.each(peoples, function(i, val) {    $.each(val, function(key, name) {        if (name === "john")            console.log(key + " : " + name);       });});但是由于有 2 個 john,我如何匹配一個特定的(例如,喜歡壽司的 john)然后返回整個匹配的對象(在 json 中)?我嘗試在 if 語句中添加另一個條件,但這似乎不起作用。謝謝
查看完整描述

5 回答

?
qq_遁去的一_1

TA貢獻1725條經驗 獲得超8個贊

你可以find用來檢查完全匹配



var peoples = [

  { "name": "bob", "dinner": "pizza" },

  { "name": "john", "dinner": "sushi" },

  { "name": "larry", "dinner": "hummus" },

  { "name": "john", "dinner": "pie" }

];


var filteredResult = peoples.find(val => val.name ==="john" && val.dinner==="sushi");

console.log(filteredResult)


查看完整回答
反對 回復 2022-10-13
?
波斯汪

TA貢獻1811條經驗 獲得超4個贊

_.按 lodash 過濾

您可以通過 lodash 使用過濾器方法迭代集合的元素,返回所有元素的數組謂詞返回truthy for。謂詞使用三個參數調用:(值,索引|鍵,集合)。它返回一個新數組

https://lodash.com/docs/4.17.15#filter

lodash 上的過濾器使用示例

var users = [{

    'user': 'barney',

    'age': 36,

    'active': true

  },

  {

    'user': 'fred',

    'age': 40,

    'active': false

  },

  {

    'user': 'fred',

    'age': 39,

    'active': true

  }

];


console.log("matches:", _.filter(users, function(o) {

  return !o.active;

}));

// => [{ active: true, age: 36, user: "barney"}]


// The `_.matches` iteratee shorthand.

console.log("_.matches` iteratee", _.filter(users, {

  'user': 'fred',

  'active': true

}));

// => [{ active: true, age: 39, user: "fred"}]


// The `_.matchesProperty` iteratee shorthand.

console.log("matchs poperty", _.filter(users, ['active', false]));

// => objects for ['fred']


// The `_.property` iteratee shorthand.

_.filter(users, 'active');

// => objects for ['barney']

<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.17.15/lodash.min.js"></script>


_.where by underscore.js

你還可以使用underscore.js 的where方法查看列表中的每個值,返回一個包含與屬性中列出的鍵值對匹配的所有值的數組。 _.where(list, properties)


_.where 用法示例 _.where(listOfPlays, {author: "Shakespeare", year: 1611});


您基本上可以在普通的 javascript 中使用過濾器方法

var peoples = [

  { "name": "bob", "dinner": "pizza" },

  { "name": "john", "dinner": "sushi" },

  { "name": "john", "dinner": "sushi" },

  { "name": "larry", "dinner": "hummus" },

  { "name": "john", "dinner": "pie" }

];


var dinner = peoples.filter(e=>e.name ==="john" && e.dinner==="sushi");


console.log(dinner)


您也可以使用 jquery grep

var peoples = [

  { "name": "bob", "dinner": "pizza" },

  { "name": "john", "dinner": "sushi" },

  { "name": "john", "dinner": "sushi" },

  { "name": "larry", "dinner": "hummus" },

  { "name": "john", "dinner": "pie" }

];


var dinner = $.grep(peoples, function(people) {

    return people.name === "john" && people.dinner === "sushi";

});


console.log(dinner)

<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>


查找 vs 過濾器

var peoples = [

  { "name": "bob", "dinner": "pizza" },

  { "name": "john", "dinner": "sushi" },

  { "name": "john", "dinner": "sushi" },

  { "name": "larry", "dinner": "hummus" },

  { "name": "john", "dinner": "pie" }

];


var filterDinner = peoples.filter(e=>e.name ==="john" && e.dinner==="sushi");


// return all matching results

console.log('filter dinner -:', filterDinner);


var findDinner = peoples.find(e=>e.name ==="john" && e.dinner==="sushi");


//returns the first matching rslt

console.log('find dinner -:', findDinner);


不推薦使用 Find,因為它返回第一個匹配結果,并且假設我們有更多匹配結果,它們會被遺漏。


查看完整回答
反對 回復 2022-10-13
?
元芳怎么了

TA貢獻1798條經驗 獲得超7個贊

考慮以下。


var peoples = [{

    "name": "bob",

    "dinner": "pizza"

  },

  {

    "name": "john",

    "dinner": "sushi"

  },

  {

    "name": "larry",

    "dinner": "hummus"

  },

  {

    "name": "john",

    "dinner": "pie"

  }

];


$.each(peoples, function(i, val) {

  if (val.name == "john" && val.dinner == "sushi") {

    console.log("Persons[" + i + "]." + Object.keys(val)[0] + ": " + val.name);

  }

});

<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>


這會迭代所有項目并比較每個項目的元素。



查看完整回答
反對 回復 2022-10-13
?
qq_花開花謝_0

TA貢獻1835條經驗 獲得超7個贊

我不知道上下文,但可能有兩個 john 并且都將晚餐屬性設置為 pie。我建議對數組中的每個條目使用 id 。如果您正在使用的數組是您列出的數組,您可以map在執行搜索之前使用它進行投影/轉換。例如


const people = [

  { name: "bob", dinner: "pizza" },

  { name: "john", dinner: "sushi" },

  { name: "larry", dinner: "hummus" },

  { name: "john", dinner: "pie" },

];


const peopleList = people.map((person, id) => ({ id, ...person }));


console.log(peopleList);


// You could start from here to search by id


查看完整回答
反對 回復 2022-10-13
?
紫衣仙女

TA貢獻1839條經驗 獲得超15個贊

您可以設置一個函數來定義您的搜索詞,然后使用Array.filter:


const peoples = [

  { "name": "bob", "dinner": "pizza" },

  { "name": "john", "dinner": "sushi" },

  { "name": "larry", "dinner": "hummus" },

  { "name": "john", "dinner": "pie" }

];


searchTerms = (person) => {

  return person.name === "john" && person.dinner === "sushi";

}


console.log(peoples.filter(searchTerms));


// [{ "name": "john", "dinner": "sushi" }]


查看完整回答
反對 回復 2022-10-13
  • 5 回答
  • 0 關注
  • 193 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號