vue样式 多个class添加与移出

vue样式 class添加与移出

//可进行多个判断 进行加类 与移出类名
//active,aeactive,active1,aeactive1 为类名
<span
                    class="nav"
                    :class="{active:oneactive==1,secactive:twoactive==2}"
                  >第一</span>
                  <span
                    class="nav"
                    :class="{active1:twoactive==1,secactive1:oneactive==2}"
                  >第二</span>

vue3使用

import { ref } from 'vue'
export default {
  setup () {
    const oneactive= ref(1)
    const twoactive= ref(1)
    return {oneactive,twoactive}
}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,根据你的要求,我给你提供一个简单的代码示例: ```html <template> <div class="notice-wrapper"> <div class="notice-content" v-for="(notice, index) in notices" :key="index" ref="notice"> <span>{{ notice }}</span> </div> </div> </template> <script> export default { data() { return { notices: ['公告1', '公告2', '公告3'], // 公告列表 intervalId: null, // 定时器ID }; }, mounted() { this.startScroll(); // 组件挂载时开始滚动 }, methods: { // 开始滚动 startScroll() { this.intervalId = setInterval(() => { const firstNotice = this.$refs.notice[0]; const height = firstNotice.offsetHeight; this.$refs.notice[0].style.marginTop = `-${height}px`; this.notices.push(this.notices.shift()); }, 2000); }, // 停止滚动 stopScroll() { clearInterval(this.intervalId); }, }, // 监听鼠标进入和离开事件 created() { this.$parent.$on('mouse-enter', this.stopScroll); this.$parent.$on('mouse-leave', this.startScroll); }, // 解绑事件 beforeDestroy() { this.$parent.$off('mouse-enter', this.stopScroll); this.$parent.$off('mouse-leave', this.startScroll); }, }; </script> <style> .notice-wrapper { height: 50px; overflow: hidden; } .notice-content { line-height: 50px; height: 50px; transition: margin-top 0.5s linear; } </style> ``` 在这个示例中,我们使用v-for指令遍历公告列表,使用CSS实现滚动效果。在组件挂载时,调用startScroll方法开始滚动,使用setInterval实现定时滚动。在鼠标进入和离开事件中,分别调用stopScroll和startScroll方法,实现鼠标移出停止滚动的效果。注意,在监听事件和解绑事件时,我们使用了$parent来访问父组件,因为鼠标事件是在父组件中触发的。 希望这个示例可以帮到你,如果还有什么不明白的地方,可以继续问我哦~

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值