vue实现手风琴

原理:为每一个项传入特定序号,实现特定项的展示(手风琴效果)
(使用vue-cli 可直接复制查看效果)
<template>
  <!--手风琴组件-->
  <div class="hello">
    <ul>
      <li>
        <span @click="toggle(1)">一条</span>
        <div v-show="show===1">
          一万
        </div>
      </li>
      <li>
        <span @click="toggle(2)">二条</span>
        <div v-show="show===2">
          贰万
        </div>
      </li>
      <li>
        <span @click="toggle(3)">三条</span>
        <div v-show="show===3">
          叁万
        </div>
      </li>
    </ul>
  </div>
</template>

<script>
export default {
  name: 'HelloWorld',
  data () {
    return {
      show:''
    }
  },
  methods:{
    toggle:function(index){
      if(this.show===index){
        this.show=0;
      }
      else{
        this.show=index;
      }
    }
  }
}
</script>
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
手风琴动画是指在一组元素中,其中一个元素被展开时,其他元素同时被收缩,形成一个类似于手风琴的效果。在 Vue 移动端开发中,可以使用 transition 动画来实现手风琴效果。 首先,在 HTML 中定义一组需要展开和收缩的元素,可以使用 v-for 指令来动态渲染元素,并绑定一个 active 变量表示当前展开元素的索引: ``` <div class="accordion"> <div v-for="(item, index) in items" :key="index" :class="{ active: index === active }"> <div class="title" @click="toggle(index)"> {{ item.title }} </div> <div class="content"> {{ item.content }} </div> </div> </div> ``` 其中,toggle 方法用于切换展开和收缩状态: ``` methods: { toggle(index) { this.active = index === this.active ? -1 : index; } } ``` 接下来,在 CSS 中定义手风琴动画的样式,使用 transform 属性实现元素的展开和收缩: ``` .accordion { .title { cursor: pointer; } .content { overflow: hidden; transition: height 0.3s ease-out; &.active { height: auto; transition: height 0.3s ease-in; } } } ``` 其中,active 类用于控制元素的展开和收缩状态,当元素被激活时,添加 active 类,并将高度设置为 auto,实现元素的展开效果;当元素被取消激活时,移除 active 类,并将高度设置为 0,实现元素的收缩效果。 最后,在 Vue 中使用 transition 组件包裹元素,实现动画效果: ``` <transition name="accordion"> <div v-for="(item, index) in items" :key="index" :class="{ active: index === active }"> <div class="title" @click="toggle(index)"> {{ item.title }} </div> <div class="content"> {{ item.content }} </div> </div> </transition> ``` 其中,name 属性用于指定动画的名称,可以在 CSS 中定义对应的动画样式。 这样就完成了手风琴动画的实现
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值