扫码关注官方订阅号
具体问题是如下图,我点击任意一个p,文本内容换成正在播放,其他不变,点击另外的当前换成正在播放,其他恢复成点击试听,如果再次点击正在播放的,自身恢复成点击试听,没有引用JQ之类的,用vue的思想应该如何制作啊,求思路
光阴似箭催人老,日月如移越少年。
<template> <p v-for="item in list" @click="onPlay(item)"> <p v-if="item.id === activeId">正在播放</p> <p v-else>点击试听</p> </p> </template> <script> export default { data() { return { list: [], activeId: -1 } }, methods: { onPlay(item) { // 与当前播放 id 一致,说明点击的是正在播放的项,变为 -1,否则当前播放 id 改为点击的项 this.activeId = item.id === this.activeId ? -1 : item.id } } } </script>
数据变化驱动视图变化。
微信扫码关注PHP中文网服务号
QQ扫码加入技术交流群
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
PHP学习
技术支持
返回顶部
数据变化驱动视图变化。