欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue 過濾器和自定義指令的使用

 更新時(shí)間:2021年05月20日 11:54:17   作者:Rouvan  
本文主要介紹Vue.js中過濾器和自定義指令相關(guān)的知識(shí)點(diǎn),包括過濾器的定義方式,和使用方法,以及自定義指令的概念和注冊(cè)方式。

過濾器

01. 是什么

過濾器可以對(duì)我們傳入的數(shù)據(jù)進(jìn)行必要的處理,并返回處理的結(jié)果

  • 過濾器不會(huì)修改數(shù)據(jù)
  • 過濾器的本質(zhì)是函數(shù)
  • 過濾器函數(shù)應(yīng)該有參數(shù),參數(shù)必須包含你想進(jìn)行處理的源數(shù)據(jù)
  • 過濾器應(yīng)該有返回值,返回處理后的結(jié)果
export default {
    // 通過filters創(chuàng)建局部過濾器
    filters:{
        過濾器名稱(data){
            // 對(duì)傳入的data 進(jìn)行處理
            return 處理結(jié)果
        }  
    }
}

02. 怎么做

(1)定義過濾器

  • 局部過濾器:定義在組件內(nèi)部,只能在當(dāng)前組件內(nèi)使用

通過filters結(jié)構(gòu)來創(chuàng)建

export default {
    // 通過filters創(chuàng)建局部過濾器
    filters:{
      過濾器名稱(data){
          // 進(jìn)行處理
          return 處理結(jié)果
      }  
    }
}
  • 全局過濾器:通過Vue.filter創(chuàng)建全局過濾器,一次只能創(chuàng)建一個(gè),可以在任何組件中使用

需要在Vue實(shí)例創(chuàng)建之前定義

Vue.filter(過濾器名稱,(data) => {
    // do something
    return 處理結(jié)果
})

在單獨(dú)的文件中創(chuàng)建一個(gè)全局過濾器
在需要用到的組件中引入,并在filters中注冊(cè)

import Vue from 'vue'
// 通過Vue.filter創(chuàng)建全局過濾器
const filter1 = Vue.filter(過濾器名稱,(data) => {
    // do something
    return 處理結(jié)果
})
// 導(dǎo)出
export {
    filter1
}
// 在組件中--引入過濾器
import { filter1 } from '@/utils/filters.js'

export default {
    // 在組件內(nèi)的 filters中,添加過濾器
    // filters既可以創(chuàng)建過濾器,又可以用來注冊(cè)過濾器
    // 只有在filters中注冊(cè)的才會(huì)被認(rèn)為是過濾器
    filters: {
        filter1
    }
}

(2)使用方式

  • 在插值表達(dá)式{{}}中,或者v-bind表達(dá)式中,通過管道操作符——|來使用過濾器
  • 格式:{{ 源數(shù)據(jù) | 過濾器 }}
<div> {{ 數(shù)據(jù) | 過濾器 }} </div>
  • 多次使用

過濾器支持多個(gè)并行使用,前者的處理結(jié)果,將作為后者的參數(shù)傳入

<div> {{ 數(shù)據(jù) | 過濾器1 | 過濾器2 }}</div>

(3)過濾器的參數(shù)

  • 如果沒有手動(dòng)傳遞參數(shù),那么默認(rèn)就會(huì)傳遞管道符前面的數(shù)據(jù)
  • 如果手動(dòng)的傳遞了參數(shù),也不會(huì)影響默認(rèn)參數(shù)的傳遞
    • 過濾器函數(shù)的第一個(gè)參數(shù)永遠(yuǎn)是管道符前面的數(shù)據(jù)
    • 而手動(dòng)傳遞的參數(shù),從參數(shù)列表的第二個(gè)開始,依次向后

03. 封裝過濾器函數(shù)

  • 過濾器的本質(zhì)就是一個(gè)函數(shù),所以可以在一個(gè)單文件中直接封裝一個(gè)過濾器函數(shù)
// 定義函數(shù)
const filterA = () => {}
const filterB = () => {}
// 導(dǎo)出函數(shù)對(duì)象
export { filterA, filterB }
  • 然后再需要的組件內(nèi)引入函數(shù),并注冊(cè)為過濾器
import * as filters from './filters.js'
//遍歷 filters.js 內(nèi)的方法
Object.keys(filters).forEach(key => { 
  Vue.filter(key, filters[key])
})

自定義指令

01. 是什么

  • 要對(duì)普通 DOM 元素進(jìn)行底層操作,這時(shí)候就會(huì)用到自定義指令
    • 也就是說自定義指令主要是對(duì) DOM 元素進(jìn)行操作

02. 基本概念

(1)鉤子函數(shù)

一個(gè)指令定義對(duì)象可以提供如下幾個(gè)鉤子函數(shù) (均為可選):

  • bind:只調(diào)用一次,指令第一次綁定到元素時(shí)調(diào)用,用這個(gè)鉤子函數(shù)可以定義一個(gè)綁定時(shí)執(zhí)行一次的初始化事件
  • inserted:當(dāng)被綁定的元素插入父節(jié)點(diǎn)時(shí)調(diào)用 ,只要父節(jié)點(diǎn)存在即可,即使它沒有插入文檔中
  • update:當(dāng)被綁定元素所在組件更新時(shí)調(diào)用,無論綁定的值是否發(fā)生變化都會(huì)調(diào)用。但可以通過比較更新前后的值,來忽略不必要的模板更新
  • componentUpdated:當(dāng)被綁定元素所在組件的全部更新后,即完成一次更新周期時(shí)調(diào)用
  • unbind:只調(diào)用一次,指令與元素解綁時(shí)調(diào)用

(2)參數(shù)

指令鉤子函數(shù)會(huì)被傳入以下參數(shù):

  • el:指令所綁定的元素,可以用來直接操作 DOM,即放置指令的那個(gè)元素
  • binding:一個(gè)對(duì)象,里面包含多個(gè)屬性
    • name:指令名,沒有v-前綴
    • value:指令綁定的值,可以綁定一個(gè)對(duì)象以傳遞多個(gè)值
    • oldValue:指令綁定的舊值,禁止update和componentUpdated鉤子中可用,無論值是否改變
    • expression:字符串形式的指令表達(dá)式
    • arg:傳遞給指令的參數(shù)
    • modifiers:一個(gè)包含修飾符的對(duì)象
  • vnode:Vue 編譯生成的虛擬節(jié)點(diǎn)
  • oldVnode:上一個(gè)虛擬節(jié)點(diǎn),僅在 update 和 componentUpdated 鉤子中可用
// <div v-demo:left="100"></div>
// 這里的 left 即為指令的 bingding對(duì)象的arg
// 100 即為指令的 bingding對(duì)象的value
Vue.directive('demo',{
    // el--表示被綁定的元素,即指令在放置的那一個(gè)元素
    bind(el,binding,vnode){
        // 可以直接對(duì)這個(gè)元素進(jìn)行一些處理
        el.style.position = 'fixed';
        const s = ( binding.arg == 'left' ? 'left' : top );
        el.style[s] = binding.value + 'px';
    }
})

03. 指令注冊(cè)

(1)全局注冊(cè)

通過 Vue.directive() 方式注冊(cè)全局指令,包含兩個(gè)參數(shù):

  • 第一個(gè)參數(shù)為自定義指令名稱,指令名稱不需要加 v- 前綴,默認(rèn)是自動(dòng)加上前綴的,在使用指令的時(shí)候加上前綴即可
  • 第二個(gè)參數(shù)可以是對(duì)象數(shù)據(jù),也可以是一個(gè)指令函數(shù)
Vue.directive("指令名稱", {
    inserted: function(el){
        // do something
    }
})

(2)局部注冊(cè)

通過在Vue實(shí)例中添加 directives 對(duì)象數(shù)據(jù)注冊(cè)局部自定義指令

export default {
    directives: {
        指令名:{
            函數(shù)
        }
    }
}

以上就是vue 過濾器和自定義指令的使用的詳細(xì)內(nèi)容,更多關(guān)于vue 過濾器和自定義指令的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 關(guān)于vue3.0使用axios報(bào)錯(cuò)問題

    關(guān)于vue3.0使用axios報(bào)錯(cuò)問題

    這篇文章主要介紹了vue3.0使用axios報(bào)錯(cuò)問題記錄,vue-cli3.0安裝插件的時(shí)候要注意區(qū)分vue-cli2.0的命令,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-08-08
  • 完美解決vue 中多個(gè)echarts圖表自適應(yīng)的問題

    完美解決vue 中多個(gè)echarts圖表自適應(yīng)的問題

    這篇文章主要介紹了完美解決vue 中多個(gè)echarts圖表自適應(yīng)的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • Vue基于NUXT的SSR詳解

    Vue基于NUXT的SSR詳解

    這篇文章主要介紹了Vue基于NUXT的SSR詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-10-10
  • Vue 2.0 基礎(chǔ)詳細(xì)

    Vue 2.0 基礎(chǔ)詳細(xì)

    這篇文章主要介紹了Vue 2.0 基礎(chǔ),具體內(nèi)容有、基本語法、生命周期、路由管理Vue-Router、狀態(tài)管理Vuex、Http請(qǐng)求庫Axios,想詳細(xì)了解的小伙伴請(qǐng)和現(xiàn)編一起學(xué)習(xí)下面文章內(nèi)容吧
    2021-10-10
  • Vue3中v-for的使用示例詳解

    Vue3中v-for的使用示例詳解

    本文主要介紹了Vue3中v-for的使用方法,包括遍歷數(shù)組、遍歷對(duì)象、索引訪問、嵌套遍歷以及結(jié)合計(jì)算屬性和方法的使用,v-for可以幫助用戶動(dòng)態(tài)地生成和管理列表數(shù)據(jù),并根據(jù)需要進(jìn)行復(fù)雜的DOM操作,提供了多種示例,幫助讀者更好地理解和使用v-for
    2024-10-10
  • vue中調(diào)用百度地圖獲取經(jīng)緯度的實(shí)現(xiàn)

    vue中調(diào)用百度地圖獲取經(jīng)緯度的實(shí)現(xiàn)

    最近做個(gè)項(xiàng)目,需要實(shí)現(xiàn)獲取當(dāng)前位置的經(jīng)緯度,所以本文主要介紹了vue中調(diào)用百度地圖獲取經(jīng)緯度的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • vue組件jsx語法的具體使用

    vue組件jsx語法的具體使用

    本篇文章主要介紹了vue組件jsx語法的具體使用,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-05-05
  • Vue 技巧之控制父類的 slot

    Vue 技巧之控制父類的 slot

    插槽(Slot)是Vue提出來的一個(gè)概念,正如名字一樣,插槽用于決定將所攜帶的內(nèi)容,插入到指定的某個(gè)位置,從而使模板分塊,具有模塊化的特質(zhì)和更大的重用性。
    2020-02-02
  • Vue v-model組件封裝(類似彈窗組件)

    Vue v-model組件封裝(類似彈窗組件)

    這篇文章主要介紹了Vue中的 v-model組件封裝(類似彈窗組件),本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-01-01
  • vue element插件this.$confirm用法及說明(取消也可以發(fā)請(qǐng)求)

    vue element插件this.$confirm用法及說明(取消也可以發(fā)請(qǐng)求)

    這篇文章主要介紹了vue element插件this.$confirm用法及說明(取消也可以發(fā)請(qǐng)求),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10

最新評(píng)論