vue 两个div高度保持一致

HTML 结构:

<div id="app">
  <div class="div1" :style="{ height: maxHeight + 'px' }">Content 1</div>
  <div class="div2" :style="{ height: maxHeight + 'px' }">Content 2</div>
</div>

Vue.js 代码:

new Vue({
  el: '#app',
  data: {
    maxHeight: 0
  },
  mounted() {
    this.updateHeight();
    window.addEventListener('resize', this.updateHeight);
  },
  beforeDestroy() {
    window.removeEventListener('resize', this.updateHeight);
  },
  methods: {
    updateHeight() {
      const div1 = this.$el.querySelector('.div1');
      const div2 = this.$el.querySelector('.div2');
      
      const maxHeight = Math.max(div1.offsetHeight, div2.offsetHeight);
      this.maxHeight = maxHeight;
    }
  }
});

我定义了一个 Vue 实例,并将其绑定到 #app 元素上。通过在实例的 data 中定义 maxHeight 属性

mounted 钩子函数中,调用 updateHeight 方法来初始化 maxHeight 值,并监听窗口的 resize 事件以在窗口大小变化时更新高度。在 beforeDestroy 钩子函数中,移除了监听器,以防止内存泄漏。

updateHeight 方法中,使用 this.$el.querySelector() 方法获取了两个 <div> 元素,并计算它们的最大高度。然后,将最大高度赋值给 maxHeight 属性。

通过以上代码,两个独立的 <div> 元素的高度将会保持一致,并随着窗口大小的改变而更新。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值