Vue.directive("custom", {
inserted(el, binding, vnode) {
let val = binding.value;
let arg = binding.arg
let mods = binding.modifiers
let expr = binding.expression
let cont = vnode.context
.... // modify loop
}
})我试图在vue中构建一个自定义指令。这个指令可以在v-for循环的内部或外部触发.当它在v-for循环中触发时,我需要当前迭代的上下文。
v-for="item in list" // i need the context for item但我不知道该怎么得到它。即使使用v的版本,也包括索引。
v-for="(item, index) in list" // i need the context for item这两个值都不能在指令insert函数中访问。至少我哪儿都找不到他们。
如果能帮助定位这些值,我们将不胜感激。
发布于 2018-11-16 17:23:15
来自https://v2.vuejs.org/v2/guide/custom-directive.html
通过这些参数传递指令钩子: el:指令绑定到的元素。这可以用于绑定:包含以下属性的对象。 ..。 value:传递给指令的值。例如,在v指令=“1+ 1”中,值为2。
你已经在这里了
let val = binding.value;你只需要把它传递给指令。
<div v-for="item in list" :v-custom="item"></div>发布于 2018-11-16 17:23:22
使用value在binding 指令钩子参数中。
例如,在v-custom="item"中,value将是item。
Vue.directive("custom", {
inserted(el, binding, vnode) {
let val = binding.value; // this value is the item
let arg = binding.arg
let mods = binding.modifiers
let expr = binding.expression
let cont = vnode.context
.... // modify loop
}
})示例(见日志):
Vue.directive("custom", {
inserted(el, binding, vnode) {
let val = binding.value;
let arg = binding.arg
let mods = binding.modifiers
let expr = binding.expression
let cont = vnode.context
console.log(val)
}
})
new Vue({
el: "#app",
data: {
todos: [{
text: "Learn JavaScript",
done: false
},
{
text: "Learn Vue",
done: false
},
{
text: "Play around in JSFiddle",
done: true
},
{
text: "Build something awesome",
done: true
}
]
},
methods: {
toggle: function(todo) {
todo.done = !todo.done
}
}
})body {
background: #20262E;
padding: 20px;
font-family: Helvetica;
}
#app {
background: #fff;
border-radius: 4px;
padding: 20px;
transition: all 0.2s;
}
li {
margin: 8px 0;
}
h2 {
font-weight: bold;
margin-bottom: 15px;
}
del {
color: rgba(0, 0, 0, 0.3);
}<script src="https://cdn.jsdelivr.net/npm/vue@2.5.17/dist/vue.js"></script>
<div id="app">
<h2>Todos:</h2>
<ol>
<li v-for="todo in todos" v-custom="todo">
<label>
<input type="checkbox"
v-on:change="toggle(todo)"
v-bind:checked="todo.done">
<del v-if="todo.done">
{{ todo.text }}
</del>
<span v-else>
{{ todo.text }}
</span>
</label>
</li>
</ol>
</div>
https://stackoverflow.com/questions/53341782
复制相似问题