Vue中事件委托的使用
事件委托即是把点击事件委托给父节点,从而解决监听器过多的问题。
Vue中使用示例如下:
<center class="range" @click="selectTimeRange"> <span data-value="0" class="selected">全部</span> <span data-value="1">近半年</span> <span data-value="2">近一个月</span> <span data-value="3">近一周</span> </center>
在父元素使用事件委托绑定selectTimeRange函数,在函数里使用e.target获取点击的对象。
selectTimeRange(e) { let value = e.target.getAttribute('data-value') console.log(value) let eles = document.querySelectorAll('.range span') let ele = eles[value] for(let item of eles){ item.classList.remove('selected') } ele.classList.add('selected') }
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步