vue中实时监听div元素盒子的宽高方法
在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宽高内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
vue使用event.dataTransfer实现A容器数据拖拽复制到B容器方式
这篇文章主要介绍了vue使用event.dataTransfer实现A容器数据拖拽复制到B容器方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2026-02-02
Vue3中使用Element Plus时el-icon无法显示的问题解决
我们的Vue前端一般都是用的ElementUI,其中按钮可能用到的比较多,官方里面有自带的一些默认图标,下面这篇文章主要给大家介绍了关于Vue3中使用Element Plus时el-icon无法显示的问题解决,需要的朋友可以参考下2022-03-03
VUE element-ui 写个复用Table组件的示例代码
本篇文章主要介绍了VUE element-ui 写个复用Table组件的示例代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-11-11


最新评论