vue之自定義過(guò)濾器(六)

一、過(guò)濾器介紹:
1缚甩、在Vue中會(huì)通過(guò)過(guò)濾器(Filters)來(lái)渲染數(shù)據(jù),使視圖可讀性更加優(yōu)雅冈钦。
2宾袜、Vue中的過(guò)濾器不能替代Vue中的methods、computed或者watch绅络,但有時(shí)候功能卻是可以達(dá)到相同的效果
3、過(guò)濾器不改變真正的data衷恭,而只是改變渲染的結(jié)果灭袁,并返回過(guò)濾后的版本
4窗看、過(guò)濾器可以保持API響應(yīng)的干凈茸歧,并在前端處理數(shù)據(jù)的格式。
5显沈、可以有效地封裝成可重用代碼塊背后的所有邏輯软瞎。
6、在Vue 2.0中已經(jīng)沒(méi)有內(nèi)置的過(guò)濾器了拉讯,我們可以自定義過(guò)濾器涤浇。
二、過(guò)濾器分類:
全局過(guò)濾器:
Vue.filter(“過(guò)濾器名稱”,callback)
局部過(guò)濾器:
filters:{"過(guò)濾器名稱":callback}
三盖彭、過(guò)濾器的使用場(chǎng)景:
過(guò)濾器可以用在兩個(gè)地方:雙花括號(hào)插值和 v-bind 表達(dá)式 (表達(dá)式用法從 2.1.0+ 開(kāi)始支持)片挂。
<1>基礎(chǔ)語(yǔ)法:
將過(guò)濾器添加在 JavaScript 表達(dá)式的尾部件余,由“管道”符號(hào)指示:


<template>
    <div class='container'>
        <h2>{{time | format}}</h2>
        <p :class="code | colorformat">狀態(tài)<p>
    </div>
</template>
 
<script>
export default {
  data() {
    return {
      time: 1534502396,
      code: 1
    };
  },
  filters: {
    format(val) {
      let date = new Date(val * 1000);
      let y = date.getFullYear();
      let m = date.getMonth() + 1;
      let d = date.getDate();
      m = m >= 10 ? m : "0" + m;
      d = d >= 10 ? d : "0" + d;
      return y + "-" + m + "-" + d;
    },
    colorformat(val){
      let cls = '';
      val == 1 ? cls = 'red' : cls='green';
      return cls;
  }
};

<2>多個(gè)過(guò)濾器串聯(lián)
多個(gè)過(guò)濾器串聯(lián)時(shí)岳颇,會(huì)將前一個(gè)過(guò)濾器的結(jié)果作為參數(shù)傳給下一個(gè)過(guò)濾器。


<template>
    <h2>{{num | resolveA | resolveB}}</h2>
</template>
<script>
export default {
  data() {
    return {
      num: 50
    };
  },
  filters: {
    resolveA(val) {
      if (val < 30) {
        return 0.4 * val + 50;
      } else {
        return (1.25 * val + 0.4 * 30) / 3;
      }
    },
    resolveB(val){
        return val.toFixed(2);
    }
  }
};
</script>

<3>雙向過(guò)濾器
目前我們使用過(guò)濾器都是在把來(lái)自模型的值顯示在視圖之前轉(zhuǎn)換它玩讳。不過(guò)也可以定義一個(gè)過(guò)濾器误窖,在把來(lái)自視圖(<input> 元素)的值寫(xiě)回模型之前轉(zhuǎn)化它:

Vue.filter('currency', {
  // model -> view
  // 在更新 `<input>` 元素之前格式化值
  read: function(val) {
    return '$'+val.toFixed(2)
  },
  // view -> model
  // 在寫(xiě)回?cái)?shù)據(jù)之前格式化值
  write: function(val, oldVal) {
    var number = +val.replace(/[^\d.]/g, '')
    return isNaN(number) ? 0 : parseFloat(number.toFixed(2))
  }
})

如果感覺(jué)有幫助,可以關(guān)注和點(diǎn)贊!S驯恰胸梆!

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市糜俗,隨后出現(xiàn)的幾起案子楔敌,更是在濱河造成了極大的恐慌,老刑警劉巖黑忱,帶你破解...
    沈念sama閱讀 218,607評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,239評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人,你說(shuō)我怎么就攤上這事〉敉” “怎么了霎褐?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,960評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵跋炕,是天一觀的道長(zhǎng)德召。 經(jīng)常有香客問(wèn)我痴脾,道長(zhǎng)颤介,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,750評(píng)論 1 294
  • 正文 為了忘掉前任赞赖,我火速辦了婚禮滚朵,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘前域。我一直安慰自己辕近,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,764評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布匿垄。 她就那樣靜靜地躺著移宅,像睡著了一般归粉。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上漏峰,一...
    開(kāi)封第一講書(shū)人閱讀 51,604評(píng)論 1 305
  • 那天糠悼,我揣著相機(jī)與錄音,去河邊找鬼浅乔。 笑死绢掰,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的童擎。 我是一名探鬼主播,決...
    沈念sama閱讀 40,347評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼攻晒,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼顾复!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起鲁捏,我...
    開(kāi)封第一講書(shū)人閱讀 39,253評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤芯砸,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后给梅,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體假丧,經(jīng)...
    沈念sama閱讀 45,702評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,893評(píng)論 3 336
  • 正文 我和宋清朗相戀三年动羽,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了包帚。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,015評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡运吓,死狀恐怖渴邦,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情拘哨,我是刑警寧澤谋梭,帶...
    沈念sama閱讀 35,734評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站倦青,受9級(jí)特大地震影響瓮床,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜产镐,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,352評(píng)論 3 330
  • 文/蒙蒙 一隘庄、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧磷账,春花似錦峭沦、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,934評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)蓬豁。三九已至,卻和暖如春菇肃,著一層夾襖步出監(jiān)牢的瞬間地粪,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,052評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工琐谤, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留蟆技,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,216評(píng)論 3 371
  • 正文 我出身青樓斗忌,卻偏偏與公主長(zhǎng)得像质礼,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子织阳,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,969評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 最近做的項(xiàng)目唧躲,一直用的Angular6.0框架造挽,期間陸陸續(xù)續(xù)完成了三四個(gè)項(xiàng)目。業(yè)務(wù)知識(shí)有一定的提升弄痹,但是一直用一個(gè)...
    月上秦少閱讀 1,275評(píng)論 0 4
  • Vue 實(shí)例 屬性和方法 每個(gè) Vue 實(shí)例都會(huì)代理其 data 對(duì)象里所有的屬性:var data = { a:...
    云之外閱讀 2,214評(píng)論 0 6
  • 本章內(nèi)容:認(rèn)識(shí) Vue.js饭入、數(shù)據(jù)綁定、計(jì)算屬性肛真、內(nèi)置指令 一谐丢、初始 Vue.js 1.1 Vue.js 是什么 ...
    了凡和纖風(fēng)閱讀 5,619評(píng)論 0 13
  • 第一章 Vue概述 what? Vue是實(shí)現(xiàn)UI層的漸進(jìn)式j(luò)s框架,核心庫(kù)關(guān)注視圖層蚓让,簡(jiǎn)單的ui構(gòu)建庇谆,復(fù)雜的路由控...
    fastwe閱讀 715評(píng)論 0 0
  • 終于有勇氣跨出這一步,一直被自己的各種理由所說(shuō)服衰腌,太忙新蟆,太累。右蕊。琼稻。既想成長(zhǎng)又懶得行動(dòng),每日是各種糾結(jié)負(fù)能量(霞姐...
    珍珍寶貝閱讀 433評(píng)論 1 4