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)文章
解決vue-cli創(chuàng)建項(xiàng)目的loader問(wèn)題
下面小編就為大家分享一篇解決vue-cli創(chuàng)建項(xiàng)目的loader問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看看吧2018-03-03
vue中實(shí)現(xiàn)在外部調(diào)用methods的方法(推薦)
下面小編就為大家分享一篇vue中實(shí)現(xiàn)在外部調(diào)用methods的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-02-02
Vue+Element-U實(shí)現(xiàn)分頁(yè)顯示效果
這篇文章主要為大家詳細(xì)介紹了Vue+Element-U實(shí)現(xiàn)分頁(yè)顯示效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-11-11
vue中的vendor.js文件過(guò)大問(wèn)題及解決
這篇文章主要介紹了vue中的vendor.js文件過(guò)大問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08
vue2.0構(gòu)建單頁(yè)應(yīng)用最佳實(shí)戰(zhàn)
這篇文章主要為大家分享了vue2.0構(gòu)建單頁(yè)應(yīng)用最佳實(shí)戰(zhàn)案例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-04-04

