【发布时间】:2019-03-26 18:34:18
【问题描述】:
我想定义一个 vue 指令,在点击时切换弹出窗口的显示,我现在拥有的是:
toggle.js
export default {
bind(el, binding) {
console.log(binding.value); // this is undefined
el.onclick = function() {
console.log(binding.value); // this is undefined as well
// toggle menu element display
};
}
};
组件.vue
<template>
<button v-toggle="$refs.menu">
...
</button>
<div ref="menu">
...
</div>
</template>
<script>
import Toggle from 'path/to/toggle.js';
export default {
name: "Component",
directives: {
Toggle
}
</script>
内部绑定函数 binding.value 始终未定义,可能是因为菜单引用尚未准备好。这样做的正确方法是什么?
【问题讨论】:
标签: javascript vue.js vuejs2