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

vue的自定義指令傳參方式

 更新時間:2022年05月30日 11:25:00   作者:harmsworth2016  
這篇文章主要介紹了vue的自定義指令傳參方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

自定義指令傳參

指令

在vue官網(wǎng)中,常用指令有v-model和v-bind,但是,如果我們需要對DOM元素進行底層操作,就需要用到自定義指令。

今天主要講到傳參的2種方式。

環(huán)境

  • vue2.3.3
  • node6.11.2
  • webpack2.6.1

這里寫圖片描述

這里寫圖片描述

傳參方式

在main.js中定義一個指令。

Vue.directive('zoom', {
? ? bind: function (el, binding, vnode) {
? ? ? ? console.log(binding)
? ? },
? ? update: function (el) {
? ? },
? ? unbind: function (el) {
? ? }
})

使用自定義指令,在任意一個html元素中,使用指令。

<div v-zoom:{a:1,b:2}="{width: 800, height: 1000}"></div>

這里寫圖片描述

方式一:v-zoom:{a:1,b:2}

  • 對于{a:1,b:2},在binding屬性中,以字符串的形式傳遞,故可以寫[1,2]、true等數(shù)據(jù)格式,但是最后拿到的都是字符串類型。

方式二:v-zoom="{width: 800, height: 1000}"

  • 等號后面的{width: 800, height: 1000},可以在binding的value屬性中獲取的數(shù)據(jù)的類型沒有變化,
  • 可以直接使用。width后面的數(shù)字,可以用當(dāng)前組件的參數(shù)替換。

參考https://cn.vuejs.org/v2/guide/custom-directive.html

自定義指令動態(tài)參數(shù)

1. 通過自定義指令中的修飾符的key作為值,更改顯示的顏色

動態(tài)指令參數(shù)

當(dāng)參數(shù)是動態(tài)的時候。

main.js

//當(dāng)參數(shù)的值是動態(tài)的時候
Vue.directive('color2', {
? bind: function(el, binding) {
? ? el.style.color = binding.value;
? }
})
Vue.directive('color3', {
? bind: function(el, binding) {
? ? el.style.color = binding.arg;
? }
})

template.vue中

<template>
<div class="demo">
? <!-- value -->
? <p v-color2='purpleUser'><i class="el-icon-user-solid"></i></p>
? <p v-color2='redUser'><i class="el-icon-user-solid"></i></p>
? <p v-color2='greenUser'><i class="el-icon-user-solid"></i></p>
? <!-- arg -->
? <p v-color3:[purpleUser]><i class="el-icon-user-solid"></i></p>
? <p v-color3:[redUser]><i class="el-icon-user-solid"></i></p>
? <p v-color3:[greenUser]><i class="el-icon-user-solid"></i></p>
</div>
</template>
<script>
export default {
? data() {
? ? return {
? ? ? purpleUser: 'purple',
? ? ? redUser: 'red',
? ? ? greenUser: 'green'
? ? }
? },
? created() {},
? methods: {}
}
</script>
<style lange='scss' scoped>
p {
? display: inline-block;
? font-size: 40px;
}
</style>

參數(shù)是靜態(tài)的,將key的值作為value,改變顏色

main.js

Vue.directive('color', {
? bind: function(el, binding) {
? ? const color = Object.keys(binding.modifiers)[0]; //將key的值作為value,改變顏色,Object.keys獲取key的值;
? ? el.style.color = color;
? }
})

template.vue中

<template>
<div class="demo">
? <p v-color.purple><i class="el-icon-user-solid"></i></p>
? <p v-color.red><i class="el-icon-user-solid"></i></p>
? <p v-color.green><i class="el-icon-user-solid"></i></p>
</div>
</template>
<script>
export default {
? data() {
? ? return {}
? },
? created() {},
? methods: {}
}
</script>
<style lange='scss' scoped>
p {
? display: inline-block;
? font-size: 40px;
}
</style>

以上的方法,最終實現(xiàn)效果是一樣的。

好了,這些僅為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 解決vue-cli創(chuàng)建項目的loader問題

    解決vue-cli創(chuàng)建項目的loader問題

    下面小編就為大家分享一篇解決vue-cli創(chuàng)建項目的loader問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看看吧
    2018-03-03
  • 關(guān)于vue的路由模式及修改方法

    關(guān)于vue的路由模式及修改方法

    這篇文章主要介紹了關(guān)于vue的路由模式及修改方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • vue中實現(xiàn)在外部調(diào)用methods的方法(推薦)

    vue中實現(xiàn)在外部調(diào)用methods的方法(推薦)

    下面小編就為大家分享一篇vue中實現(xiàn)在外部調(diào)用methods的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • Vue+Element-U實現(xiàn)分頁顯示效果

    Vue+Element-U實現(xiàn)分頁顯示效果

    這篇文章主要為大家詳細(xì)介紹了Vue+Element-U實現(xiàn)分頁顯示效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • Vue文本模糊匹配功能如何實現(xiàn)

    Vue文本模糊匹配功能如何實現(xiàn)

    這篇文章主要介紹了Vue文本模糊匹配功能如何實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-07-07
  • vue中的vendor.js文件過大問題及解決

    vue中的vendor.js文件過大問題及解決

    這篇文章主要介紹了vue中的vendor.js文件過大問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue2.0構(gòu)建單頁應(yīng)用最佳實戰(zhàn)

    vue2.0構(gòu)建單頁應(yīng)用最佳實戰(zhàn)

    這篇文章主要為大家分享了vue2.0構(gòu)建單頁應(yīng)用最佳實戰(zhàn)案例,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • element Table表格組件多字段(多列)排序方法

    element Table表格組件多字段(多列)排序方法

    最近需要做個需求,需要做到element Table表格組件多字段(多列)排序,本文就詳細(xì)的介紹一下方法,感興趣的可以了解一下
    2021-09-09
  • 老生常談vue2中watch的使用

    老生常談vue2中watch的使用

    watch的基本用法是在Vue實例中定義一個watch對象,該對象內(nèi)部包含需要監(jiān)聽的數(shù)據(jù)項和對應(yīng)的回調(diào)函數(shù),這篇文章主要介紹了vue2中watch的使用,需要的朋友可以參考下
    2024-01-01
  • Vue實現(xiàn)簡單跑馬燈特效

    Vue實現(xiàn)簡單跑馬燈特效

    這篇文章主要為大家詳細(xì)介紹了Vue實現(xiàn)簡單跑馬燈特效,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05

最新評論