height高度为auto的transition过渡无效解决

本文介绍了在Vue中处理元素高度过渡的问题,特别是当一方高度设置为auto时,如何通过nextTick获取动态高度并实现平滑过渡。示例代码展示了在卡片点击后如何改变其高度,通过监听点击事件和nextTick回调来更新元素的准确高度,确保过渡效果正常工作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

transition的高度过渡时。height有一方是auto则无效,动态获取变化后的高度重新赋值

卡片点击后高度变高:

<div>
   <a-card class="at-card" v-for="(item,index) in testData" :key="index" @click="openCard(index)" :style="{height:cardFlag===index ? autoHeight :'388px'}">
   /*点击高度auto*/
   </a-card>
</div>  
 openCard(i){
  if(this.cardFlag===i){
    this.cardFlag=''
  }else{
    this.cardFlag=i
    this.$nextTick(() => {  //高度变化过渡需要具体高度值
      const nodes = document.querySelectorAll('.at-card') 
      this.autoHeight = nodes[i].scrollHeight + 'px'
    })
  }
},
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值