第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

過濾數(shù)組值 - return 語句不會(huì)結(jié)束函數(shù)

過濾數(shù)組值 - return 語句不會(huì)結(jié)束函數(shù)

臨摹微笑 2022-06-05 16:58:36
我一直在想一些我認(rèn)為應(yīng)該很容易的事情,但我似乎無法解決。我有一個(gè)數(shù)組,其中包含不同類型的文本,這些文本未排序。因此,我想根據(jù)文本類型的優(yōu)先級僅可視化其中一個(gè)。以下是數(shù)據(jù)示例:所以我從模板觸發(fā)一個(gè)函數(shù):<ng-container *ngFor="let text of elements.Event.Texts"> <p *ngIf="textSelector(text)">{{bestText}}</p></ng-container>這是功能:textSelector(item: any) {if (item.Type === 'VeryShort') {  this.bestText = item.Value;  return true;} else {  if (item.Type === 'Short') {    this.bestText = item.Value;    return true;  } else {    if (item.Type === 'Medium') {      this.bestText = item.Value;      return true;    } else {      return false;    }  }}我只需要導(dǎo)出一個(gè)文本 - 按“文本類型”優(yōu)先級。就我而言,對于屏幕截圖中的示例,我得到了“Short”和“VeryShort”文本。有人可以給我一個(gè)提示我做錯(cuò)了什么嗎?我將不勝感激!
查看完整描述

2 回答

?
達(dá)令說

TA貢獻(xiàn)1821條經(jīng)驗(yàn) 獲得超6個(gè)贊

了解模板代碼的作用很重要:它迭代并elements.Event.Texts調(diào)用textSelector每個(gè)元素。只要返回 true,就會(huì)創(chuàng)建一個(gè)元素。textSelectorp


我會(huì)建議一種不同的方法。只調(diào)用一次函數(shù),因?yàn)槟恍枰粋€(gè)值。


 <p *ngIf="textSelector(elements.Event.Texts)">{{bestText}}</p>

這就是我編寫函數(shù)的方式。我會(huì)使用一個(gè)數(shù)組來設(shè)置優(yōu)先級,所以它更易于維護(hù)。


const order = ["VeryShort", "Short", "Medium"];


textSelector(items: any[]) {

  let bestItem;

  for (const item of items) {

    if (item.Type === order[0]) {

      this.bestText = item.Value;

      return true;

    }

    if (!bestItem) {

      bestItem = item;

    } else if (order.indexOf(item.Type) < order.indexOf(bestItem.Type)) {

      bestItem = item;

    }

  }

  if (!bestItem) {

    return false;

  }

  this.bestText = bestItem.Value;

  return true;

}

如果您有任何問題或需要解釋,請告訴我。


查看完整回答
反對 回復(fù) 2022-06-05
?
精慕HU

TA貢獻(xiàn)1845條經(jīng)驗(yàn) 獲得超8個(gè)贊

試試這個(gè)。它可能有效


textSelector(item: any) {


if (item.Type === 'VeryShort') {

  this.bestText = item.Value;

  return true;

} else  if (item.Type === 'Short') {

    this.bestText = item.Value;

    return true;

  } else if (item.Type === 'Medium') {

      this.bestText = item.Value;

      return true;

    } else {

      return false;

    }

  }


查看完整回答
反對 回復(fù) 2022-06-05
  • 2 回答
  • 0 關(guān)注
  • 142 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號