vue的自定義指令傳參方式
自定義指令傳參
指令
在vue官網(wǎng)中,常用指令有v-model和v-bind,但是,如果我們需要對(duì)DOM元素進(jìn)行底層操作,就需要用到自定義指令。
今天主要講到傳參的2種方式。
環(huán)境
- vue2.3.3
- node6.11.2
- webpack2.6.1


傳參方式
在main.js中定義一個(gè)指令。
Vue.directive('zoom', {
? ? bind: function (el, binding, vnode) {
? ? ? ? console.log(binding)
? ? },
? ? update: function (el) {
? ? },
? ? unbind: function (el) {
? ? }
})使用自定義指令,在任意一個(gè)html元素中,使用指令。
<div v-zoom:{a:1,b:2}="{width: 800, height: 1000}"></div>
方式一:v-zoom:{a:1,b:2}
- 對(duì)于{a:1,b:2},在binding屬性中,以字符串的形式傳遞,故可以寫(xiě)[1,2]、true等數(shù)據(jù)格式,但是最后拿到的都是字符串類(lèi)型。
方式二:v-zoom="{width: 800, height: 1000}"
- 等號(hào)后面的{width: 800, height: 1000},可以在binding的value屬性中獲取的數(shù)據(jù)的類(lèi)型沒(méi)有變化,
- 可以直接使用。width后面的數(shù)字,可以用當(dāng)前組件的參數(shù)替換。
參考https://cn.vuejs.org/v2/guide/custom-directive.html
自定義指令動(dòng)態(tài)參數(shù)
1. 通過(guò)自定義指令中的修飾符的key作為值,更改顯示的顏色
動(dòng)態(tài)指令參數(shù)
當(dāng)參數(shù)是動(dòng)態(tài)的時(shí)候。
main.js
//當(dāng)參數(shù)的值是動(dòng)態(tài)的時(shí)候
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>以上的方法,最終實(shí)現(xiàn)效果是一樣的。

好了,這些僅為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Vue3中provide和inject作用和場(chǎng)景
Vue3中provide和inject作用和場(chǎng)景是頂層組件向任意的底層組件傳遞數(shù)據(jù)和方法,實(shí)現(xiàn)跨層組件通信,本文通過(guò)實(shí)例介紹Vue3 provide和inject的相關(guān)知識(shí),感興趣的朋友一起看看吧2023-11-11
vue.js 子組件無(wú)法獲取父組件store值的解決方式
今天小編就為大家分享一篇vue.js 子組件無(wú)法獲取父組件store值的解決方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-11-11
vue中使用scrollTo沒(méi)有效果的完美解決方法
這篇文章主要介紹了在vue中使用scrollTo沒(méi)有效果的解決方法,本文給大家分享具體操作步驟,在這里需要注意scrollTo要作用在可滾動(dòng)的元素上,不然不生效,scrollTop就會(huì)一直為0,需要的朋友可以參考下2023-10-10
vue.js 圖片上傳并預(yù)覽及圖片更換功能的實(shí)現(xiàn)代碼
這篇文章主要介紹了vue.js 圖片上傳并預(yù)覽及圖片更換功能,小編主要圍繞我們?nèi)粘J褂霉δ艿睦幼鲋v解,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-08-08
Vue調(diào)用PC攝像頭實(shí)現(xiàn)拍照功能
這篇文章主要為大家詳細(xì)介紹了Vue調(diào)用PC攝像頭實(shí)現(xiàn)拍照功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09

