VUE.JS 在 FOR 循环中选择一个元素

Posted

技术标签:

【中文标题】VUE.JS 在 FOR 循环中选择一个元素【英文标题】:VUE.JS Selecting a element inside a FOR loop 【发布时间】:2017-10-03 08:48:50 【问题描述】:

当用户点击另一个元素时,我试图显示/隐藏一个 DIV。两者都在 FOR 循环的每个元素内,使用 VUE JS 动态加载。

例子:

Item A 
Item B 
Item C 

当项目 A 被点击时:

Item A
INITIALLY HIDDEN ELEMENT
Item B
Item C

当项目 b 被点击时:

Item A
Item B
INITIALLY HIDDEN ELEMENT
Item C

我的(非常简单的)代码:

<tr v-for="item in items">
        <td>
             <span id="TRIGGER" @click="????">item.name</span>

             <div id="SHOW/HIDE DIV"></div>
        </td>
</tr>

在我的尝试中,我创建了一个布尔变量,并在点击时更改了值。但它(显然)从所有 FOR 元素中显示/隐藏所有 div。

【问题讨论】:

【参考方案1】:

存储对可见项的引用,以便您可以将其作为可见性触发器进行引用。

确保添加一个名为visibledata 属性,初始化为null

data: () => (
  items: [], // loaded dynamically
  visible: null
)
<tr v-for="(item, index) in items">
  <td>
    <span :id="`TRIGGER_$index`" @click="visible = item">item.name</span>

    <div :id="`SHOW-HIDE-DIV_$index`" v-show="item === visible"></div>
  </td>
</tr>

【讨论】:

完美运行!谢谢!!

以上是关于VUE.JS 在 FOR 循环中选择一个元素的主要内容,如果未能解决你的问题,请参考以下文章

Vue.js v-for 循环遍历数组不起作用(非零长度的零元素)

Vue.js 循环语句

从循环Vue.js中的每个选择中获取数据

使用 p 标签的嵌套 v-for 循环在 Vue.js 中不起作用

在 v-for vue js 中自动选择第一个选项

如何在 Vue.js 的嵌套 v-for 循环中使用 v-html 有条件地渲染原始 HTML?