中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue過濾器怎么自定義及使用

發布時間:2022-11-21 09:54:31 來源:億速云 閱讀:134 作者:iii 欄目:開發技術

這篇文章主要介紹“Vue過濾器怎么自定義及使用”,在日常操作中,相信很多人在Vue過濾器怎么自定義及使用問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Vue過濾器怎么自定義及使用”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

1. 簡單介紹

Vue.js 允許你自定義過濾器(filter),可被用于一些常見的文本格式化。

過濾器可以用在兩個地方:雙花括號插值和 v-bind 表達式 (后者從 2.1.0+ 開始支持)。

過濾器應該被添加在 JavaScript 表達式的尾部,由“管道”符號指示:

<!-- 在雙花括號中 -->
{{ message | filter }}

<!-- 在 `v-bind` 中 -->
<div v-bind:msg="message | filter"></div>

過濾器函數總接收表達式的值作為第一個參數。

在上述例子中,filter 過濾器函數將會收到 message 的值作為第一個參數。

1.1 過濾器可以串聯

{{ message | filterA | filterB }}

在這個例子中,filterA 被定義為接收單個參數的過濾器函數,表達式 message 的值將作為參數傳入到函數中。然后繼續調用同樣被定義為接收單個參數的過濾器函數 filterB,將 filterA 的結果傳遞到 filterB 中。

1.2 過濾器是 JavaScript 函數可以接收參數

{{ message | filterA('arg1', arg2) }}

filterA 被定義為接收三個參數的過濾器函數。其中 message 的值作為第一個參數,普通字符串 'arg1' 作為第二個參數,表達式 arg2 的值作為第三個參數。

2. vue-cli中定義全局過濾器

語法:Vue.filter( filterName,( ) => { return // 數據處理結果 } )

eg:

<div id="app">
  <h4>{{userName | addName}}</h4>
</div>
<script>
// 參數一:是過濾器的名字,也就是管道符后邊的處理函數;
// 參數二:處理函數,處理函數的參數同上	
Vue.filter("addName",(value)=>{											            
    return "my name is" + value
})
let vm = new Vue({
    el:"#app",
  	data:{
     userName:"小明" 
    }
})
</script>

2.1 實際開發使用

全局過濾器經常會被在數據修飾上,通常我們把處理函數給抽離出去,統一放在一個.js文件中。

// filter.js 文件

let filterPrice = (value) => {
	return '已收款' + value + '元'
}
let filterDate = (value) => {
    return value + '天'
}

export default {filterPrice,filterDate}

在main.js中 導入 上邊 filter.js文件 ,也可以在任何組件中導入 filter.js這個文件,但對于全局過濾器來說,最好是在main.js中定義,導入的是一個對象,所以使用Object.keys()方法,得到一個由key組成的數組,遍歷數據,讓key作為全局過濾器的名字,后邊的是key對應的處理函數,這樣在任何一個組件中都可以使用全局過濾器了:

//main.js
 
//下邊是2種導入方式,推薦第一種
import * as filters from './utils/filter/filter'
// import {filterPrice,filterDate} from './utils/filter/filter'
 
console.log(filters)
 
Object.keys(filters.default).forEach((item)=>{
  Vue.filter(item,filters.default[item])
})
 
new Vue({
  router,
  store,
  render: h => h(App),
}).$mount('#app')

Vue過濾器怎么自定義及使用

3. 在組件中使用 全局過濾器:

// test.vue

<template>
  <div>
    <input type="text" v-model="filterCount" >
    <div>{{filterCount | filterPrice}}</div>
    <div>{{filterCount | filterDate}}</div>
  </div>  
</template>

<script>
export default {
  data(){
    return {
      filterCount:1500
    }
  },
}
</script>

3. vue-cli中定義局部過濾器

// test.vue

<template>
  <div>
    <input type="text" v-model="filterCount" >
    <div>{{filterCount | filterPrice}}</div>
    <div>{{filterCount | filterDate}}</div>
  </div>  
</template>

<script>
export default {
  data(){
    return {
      filterCount:1500
    }
  },
}
</script>

4. 常見使用場景

4.1 格式日期(時間)

場景一:后端傳的時間:2019-11-19T04:32:46Z

安裝moment.js

// main.js

import moment from 'moment'
// 定義全局過濾器--時間格式化
Vue.filter('format',function(val,arg){
  if(!val) return;
  val = val.toString()
  return moment(val).format(arg)
})
// test.vue

<template>
   <div class="filter">{{time | format('YYYY-MM-DD HH:MM:SS')}}</div>  
</template>

<script>
export default {
  data(){
    return {
      time:'2019-11-19T04:32:46Z'
    }
  }
}
</script>

vue是什么

Vue是一套用于構建用戶界面的漸進式JavaScript框架,Vue與其它大型框架的區別是,使用Vue可以自底向上逐層應用,其核心庫只關注視圖層,方便與第三方庫和項目整合,且使用Vue可以采用單文件組件和Vue生態系統支持的庫開發復雜的單頁應用。

到此,關于“Vue過濾器怎么自定義及使用”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

德阳市| 铜梁县| 四平市| 尉犁县| 巴彦淖尔市| 子长县| 龙川县| 漯河市| 金坛市| 青海省| 贵南县| 广饶县| 昔阳县| 荆门市| 建昌县| 溆浦县| 连南| 文水县| 长顺县| 页游| 石狮市| 高州市| 赤水市| 江川县| 昭苏县| 长阳| 忻州市| 辽源市| 泽州县| 壶关县| 乌恰县| 阳江市| 南阳市| 赞皇县| 景谷| 高州市| 万安县| 唐海县| 布拖县| 忻州市| 高密市|