监测div大小变化_js 怎么监控一个普通DIV的宽高发生变化

情形:

左右两个div,有一个小按钮,点击时候,可以控制左边的div显示或隐藏,右边的div随着左边的div隐藏显示宽度会发生变化,里面的子级元素当然也会跟着变化。

但是因为特殊情况,必须要设置右边div里面的元素为absolute。

如果左边没隐藏,左边可以把最外面的div撑开(flex布局),右边也是有高度的。

但是如果左边隐藏了,右边因为内容脱出文档流,所以高度为0,内容看不到了。

现在我需要监听右边宽度变化,设置右边内容的高度。

代码:

mounted () {

this.wrapDom = document.getElementById('tableWrap')

let MutationObserver = window.MutationObserver || window.WebKitMutationObserver || window.MozMutationObserver

let element = document.querySelector('#tableID')

this.observer = new MutationObserver((objList) => {

console.log('obj List:', objList)

let width = element.offsetWidth

if (this.recordOldValue && width === this.recordOldValue.width) {

return

}

this.recordOldValue = {

width

}

console.log('obj width:', width)

this.wrapDom.style.height = element.offsetHeight + 58 + 'px'

})

this.observer.observe(element, { attributes: true, childList: true, subtree: true })

},

beforeDestroy () {

// 停止观测

this.observer.disconnect()

this.observer = null

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 首先,你需要在 Vue 实例中定义一个计算属性,用于获取 div度。然后,你可以使用 Vue 的 `$watch` 函数来监听这个计算属性的变化。 例如: ``` <template> <div ref="myDiv">Some content</div> </template> <script> export default { data() { return { divWidth: 0 } }, computed: { divWidthComputed: { get() { return this.$refs.myDiv.offsetWidth } } }, mounted() { this.$watch('divWidthComputed', (newVal, oldVal) => { this.divWidth = newVal }) } } </script> ``` 在这个例子中,当 div度发生改变,计算属性 `divWidthComputed` 的值也会相应地发生改变。$watch 函数会监听这个计算属性的值,并在其发生改变执行回调函数,将新的值赋值给 `divWidth` 变量。 你也可以使用其他方法来监听 div变化,例如使用 MutationObserver 或者 ResizeObserver 等。 ### 回答2: 要监听一个div度改变,可以使用Vue中的watch属性和$refs来实现。 首先,在div元素上添加一个ref属性,将其命名为"myDiv",如下所示: ``` <div ref="myDiv"></div> ``` 然后,在Vue组件的watch属性中添加一个监听器来监测div度改变,如下所示: ``` watch: { myDivWidth: function(newWidth, oldWidth) { // 度改变执行的代码 console.log("度改变:" + newWidth); } } ``` 在Vue组件的mounted钩子函数中,可以通过this.$refs来获取div元素的引用,并通过offsetWidth属性获取其当前的度,如下所示: ``` mounted() { this.$nextTick(() => { this.myDivWidth = this.$refs.myDiv.offsetWidth; }); } ``` 在上述代码中,通过mounted钩子函数和this.$nextTick方法,确保在组件初始化渲染完成后再获取div度,并将其赋值给myDivWidth变量。 一旦div度改变,watch监听器就会被触发,执行相应的代码。在上述代码中,我们将新度newWidth打印到控制台,你可以根据需要自行修改或扩展。 完成以上操作后,你就可以监听并响应div度的改变了。 ### 回答3: 在Vue中,监听一个div度改变可以通过使用Vue的指令和监听器来实现。 首先,要确保需要监听度改变的div一个唯一的标识符或类名,以便能够在Vue中进行选择和操作。例如,我们给需要监听的div添加一个类名为"resize-div"。 然后,在Vue组件的生命周期钩子函数中,可以使用指令`v-once`和`v-resize`来监听div度的改变。 具体步骤如下: 1. 在需要监听度改变的div中添加类名"resize-div",如: ```html <div class="resize-div"></div> ``` 2. 在Vue组件的生命周期钩子函数`mounted`中,使用`querySelector`方法选择该div,并将其存储在一个变量中。 ```javascript mounted() { const resizeDiv = document.querySelector('.resize-div'); } ``` 3. 在Vue组件中的`mounted`钩子函数中,使用`ResizeObserver`监听resizeDiv度改变,并在回调函数中执行相应的操作。 ```javascript mounted() { const resizeDiv = document.querySelector('.resize-div'); const resizeObserver = new ResizeObserver((entries) => { // 获取最新的度 const width = entries[0].contentRect.width; // 执行相应的操作 // ... }); resizeObserver.observe(resizeDiv); } ``` 通过以上步骤,我们就可以监听到div度的改变,并在回调函数中执行相应的操作。请注意,使用`ResizeObserver`需要确保浏览器支持该API,如果需要兼容性更好的解决方案,可以考虑使用第三方库,比如`ResizeSensor`。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值