猿问

vue2中如何实现广播机制?

如下伪代码

<l1 id="1">
    <l2></l2>
    <l2></l2></l1><l1 id="2">
    <l2></l2>
    <l2></l2></l1><l1 id="3">
    <l2></l2>
    <l2></l2></l1>

初始时“l1”均处于闭合状态,通过对l1绑定click事件,可以控制展开/关闭自身。
但如何实现展开自身的同时关闭其他“l1”呢?
求助给个思路。


梵蒂冈之花
浏览 499回答 1
1回答

心有法竹

用不着广播,仔细从数据驱动的角度来考虑,用一个数据 curIdx 表示当前展开的组件,那么可以通过下面的类绑定来实现你所要的展开折叠状态控制:<l1 v-for="(item, idx) in items" :class="curIdx === idx ? 'expanded' : 'collapsed'" @click="curIdx = idx">&nbsp; <l2></l2></l1>
随时随地看视频慕课网APP

相关分类

JavaScript
我要回答