【vue-cli 3】全局過濾器

微信訂閱號:Rabbit_svip

在vue1.x版本里是自帶里幾個基礎(chǔ)的過濾器的(雖然不怎么用到)。
到了vue2.x版本之后,內(nèi)置到幾個過濾器就被刪掉了,如果需要用到過濾器,就要開發(fā)者自己去定義。

可以把過濾器定義在某個組件內(nèi)部,但這樣就成了局部過濾器,在別的組件里是無法使用的。所以通常不會這么做。

也可以把過濾器寫在main.js里。但如果項目中存在多個過濾器,這會使main.js文件看上去很龐大,不便于后期維護。

所以通常會新建一個js文件,專門用來存放所有過濾器。最后再引到main.js中供全局使用。


1、創(chuàng)建 filters.js

首先新建一個filters.js文件。把這個文件放在 src/assets 里。

微信訂閱號:Rabbit_svip

因為這里是用來存放靜態(tài)資源的。這個文件夾可以用來存放圖片、css和部分自定義的功能的js資源。如果需要更好的分類,可以在 assets 文件夾里再創(chuàng)建 js、 css、 img 等文件夾。


2、創(chuàng)建過濾器規(guī)則

這里我創(chuàng)建了3個過濾器

//  轉(zhuǎn)小寫
let lower = value => value.toLowerCase();

//  轉(zhuǎn)大寫
let upper = value => value.toUpperCase();

let currencyStyle = (value, style) => { //  貨幣格式
    /**
     * style: 
     *      currency:貨幣
     *      number: 數(shù)字格式
     */
    if(style == 'number') { // 數(shù)字格式
        return parseFloat(value.replace(/[^\d\.-]/g, ""));
    } else { // 貨幣格式, 并保留2位小數(shù)
        var n = 2;
        value = parseFloat((value + "").replace(/[^\d\.-]/g, "")).toFixed(n) + "";
        var l = value.split(".")[0].split("").reverse(),
            r = value.split(".")[1];
        var t = "";
        for (var i = 0; i < l.length; i++) {
            t += l[i] + ((i + 1) % 3 == 0 && (i + 1) != l.length ? "," : "");
        }
        return t.split("").reverse().join("") + "." + r;
    }
}

export {
    lower,
    upper,
    currencyStyle
}


3、在main.js里注冊全局過濾器

import Vue from 'vue'
import App from './App.vue'
import * as filters from './assets/filters'

Object.keys(filters).forEach(key => {
  Vue.filter(key, filters[key])
})

Vue.config.productionTip = false

new Vue({
  render: h => h(App),
}).$mount('#app')

通過 forEach 循環(huán),把自定義功能分別注冊到過濾器里。


4、在組件里使用

<template>
  <div id="app">
    <p>{{ num1 | currencyStyle('currency') }}</p>
    <p>{{ num2 | currencyStyle('number') }}</p>
    <p>{{ msg1 | lower }}</p>
    <p>{{ msg2 | upper }}</p>
  </div>
</template>

<script>

export default {
  name: 'app',
  data() {
    return {
      num1: 123456,
      num2: '123,456',
      msg1: 'ABC',
      msg2: 'def'
    }
  }
}
</script>
微信訂閱號:Rabbit_svip
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 第一章 Vue概述 what? Vue是實現(xiàn)UI層的漸進式j(luò)s框架,核心庫關(guān)注視圖層,簡單的ui構(gòu)建,復(fù)雜的路由控...
    fastwe閱讀 833評論 0 0
  • vue概述 在官方文檔中,有一句話對Vue的定位說的很明確:Vue.js 的核心是一個允許采用簡潔的模板語法來聲明...
    li4065閱讀 7,624評論 0 25
  • ## 框架和庫的區(qū)別?> 框架(framework):一套完整的軟件設(shè)計架構(gòu)和**解決方案**。> > 庫(lib...
    Rui_bdad閱讀 3,155評論 1 4
  • ¥開啟¥ 【iAPP實現(xiàn)進入界面執(zhí)行逐一顯】 〖2017-08-25 15:22:14〗 《//首先開一個線程,因...
    小菜c閱讀 7,356評論 0 17
  • vue-cli搭建項目 確保安裝了node與npm 再目標文件夾下打開終端 執(zhí)行cnpm i vue-cli -g...
    Akiko_秋子閱讀 3,364評論 1 22

友情鏈接更多精彩內(nèi)容