vue.js

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript类库 > vue.js > vue实时监听div宽高

vue中实时监听div元素盒子的宽高方法

作者:王.彦.凯

这篇文章主要给大家介绍了关于vue中如何实时监听div元素盒子的宽高的相关资料,在Vue中你可以使用Vue的计算属性和侦听器来动态监测元素的高度,文中给出了简单代码示例,需要的朋友可以参考下

在Vue中实时监听div盒子的宽高可以使用resize事件结合refs来实现。

首先,在div盒子上添加一个ref属性,例如:

<div ref="box"></div>

然后,在Vue组件的mounted生命周期钩子中添加事件监听:

mounted() {
  window.addEventListener('resize', this.handleResize)
},

在Vue组件的methods中定义handleResize方法来处理宽高变化:

methods: {
  handleResize() {
    const width = this.$refs.box.offsetWidth;
    const height = this.$refs.box.offsetHeight;
    // 在这里处理宽高变化的逻辑
    console.log('盒子宽度:', width, '盒子高度:', height);
  }
},

这样,每当窗口大小改变时,handleResize方法将被调用并获取到最新的宽高值。你可以在该方法中处理宽高变化的逻辑,例如更新数据、触发其他操作等。

记得在Vue组件销毁时,移除事件监听:

beforeDestroy() {
  window.removeEventListener('resize', this.handleResize)
},

这样就能实时监听div盒子的宽高了。

补充:vue如何实现实时监听页面宽度高度变化

运用的主要技术:watch监听

话不多说直接上代码,自行研究

 <template>
  <div class="rightContainer">
    <h1>监听页面宽高</h1>
    <h2>当前整个页面宽度{{ windowWidth }}px</h2>
    <h2>当前整个页面高度{{ windowHeight }}px</h2>
  </div>
</template>
<script>
export default {
  name: 'WatchsHW',
  data() {
    return {
      windowHeight: document.body.clientHeight,
      windowWidth: document.body.clientWidth
    }
  },
  watch: {
    // 监听页面高度
    windowHeight(val) {
      console.log('实时屏幕高度:', val, this.windowHeight)
    },
    // 监听页面宽度
    windowWidth(val) {
      console.log('实时屏幕宽度:', val, this.windowHeight)
    }
  },
  mounted() {
    // <!--把window.onresize事件挂在到mounted函数上-->
    window.onresize = () => {
      return (() => {
        this.windowHeight = document.documentElement.clientHeight // 高
        this.windowWidth = document.documentElement.clientWidth // 宽
      })()
    }
  },
  methods: {
  }
}
</script>
<style lang="scss" scoped>
.rightContainer{
  width: 100%;
  text-align: center;
  overflow: hidden;
}
</style>

总结

到此这篇关于vue中实时监听div元素盒子宽高的文章就介绍到这了,更多相关vue实时监听div宽高内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文