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

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

如何簡化陣列過濾器

如何簡化陣列過濾器

白衣染霜花 2022-09-23 10:00:24
我想知道如何簡化這一點,以避免重復小寫并包含每個屬性的條件。 items() {  return this.table.filter.keyword    ? this.dataArray.filter(        item =>          item.nombre.toLowerCase().includes(this.table.filter.keyword) ||          item.paisOrigen            .toLowerCase()            .includes(this.table.filter.keyword) ||          item.ciudad.toLowerCase().includes(this.table.filter.keyword) ||          item.sector.toLowerCase().includes(this.table.filter.keyword) ||          item.contratadorPor            .toLowerCase()            .includes(this.table.filter.keyword) ||          item.moneda.toLowerCase().includes(this.table.filter.keyword)      )    : this.dataArray;}
查看完整描述

2 回答

?
慕姐8265434

TA貢獻1813條經驗 獲得超2個贊

在應用過濾器之前,您可以使用地圖功能:

  1. 使用映射將值轉換為小寫(您可以使用...循環中轉換所有屬性)

  2. 對地圖結果應用過濾器。

this.data.map(item => {

  let ret = {};

  for (let p in item) {

    ret[p] = item[p].toLowerCase();

  }

  return ret;

}).filter(item => {

  //... perform your filter logic here...

});


查看完整回答
反對 回復 2022-09-23
?
忽然笑

TA貢獻1806條經驗 獲得超5個贊

如果你真的想降低重復次數,你可以做這樣的事情。


 items() {

  const lowerIncludes = (val) => val.toLowerCase().includes(this.table.filter.keyword)

  const fields = ['nombre', 'paisOrigen', 'ciudad', 'sector', 'contratadorPor', 'moneda']

  return this.table.filter.keyword ? this.dataArray.filter(item => fields.some(f => lowerIncludes(item[f]))) : this.dataArray

 }

你把它變成它自己的功能。,然后列出要包含在正在使用的過濾器中的字段。.toLowerCase().includes(this.table.filter.keyword)or


然后,您可以像所有語句一樣工作。如果關鍵字位于任何字段中,它將返回 true。fields.some(f => lowerIncludes(item[f])||


查看完整回答
反對 回復 2022-09-23
  • 2 回答
  • 0 關注
  • 103 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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