首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >访问循环上下文的Vue.js自定义指令

访问循环上下文的Vue.js自定义指令
EN

Stack Overflow用户
提问于 2018-11-16 16:22:52
回答 2查看 801关注 0票数 1
代码语言:javascript
运行
复制
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循环中触发时,我需要当前迭代的上下文。

代码语言:javascript
运行
复制
v-for="item in list"  // i need the context for item

但我不知道该怎么得到它。即使使用v的版本,也包括索引。

代码语言:javascript
运行
复制
v-for="(item, index) in list"  // i need the context for item

这两个值都不能在指令insert函数中访问。至少我哪儿都找不到他们。

如果能帮助定位这些值,我们将不胜感激。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-11-16 17:23:15

来自https://v2.vuejs.org/v2/guide/custom-directive.html

通过这些参数传递指令钩子: el:指令绑定到的元素。这可以用于绑定:包含以下属性的对象。 ..。 value:传递给指令的值。例如,在v指令=“1+ 1”中,值为2。

你已经在这里了

代码语言:javascript
运行
复制
let val = binding.value;

你只需要把它传递给指令。

代码语言:javascript
运行
复制
<div v-for="item in list" :v-custom="item"></div>
票数 0
EN

Stack Overflow用户

发布于 2018-11-16 17:23:22

使用valuebinding 指令钩子参数中。

例如,在v-custom="item"中,value将是item

代码语言:javascript
运行
复制
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
    }
})

示例(见日志):

代码语言:javascript
运行
复制
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
    }
  }
})
代码语言:javascript
运行
复制
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);
}
代码语言:javascript
运行
复制
<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>

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53341782

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档