当前位置:   article > 正文

Vue + Element UI——监听DOM元素高度和宽度解决方案整理(八种方法)_vue3监听dom元素高度变化

vue3监听dom元素高度变化

问题描述

监听DOM元素大小的变化,在前端开发中,算是一个比较常见的需求,比如我们要制作可伸缩的图表的时候,可能需要根据DOM大小的变化,进行动态的更新图表。

解决方案

方法一: 

监听window变化,再改变对应DOM变化

  1. window.onresize = function() {
  2. const width = getStyle(dom, 'width');
  3. const height = getStyle(dom, 'height');
  4. }
  5. function getStyle(ele,attr){
  6. if(window.getComputedStyle){
  7. return window.getComputedStyle(ele,null)[attr];
  8. }
  9. return ele.currentStyle[attr];
  10. }

通过这样的方式可以进行监听DOM元素的变化,但是不是最完善的。

例:通过js改变一个dom的宽度或者高度,但是window是没有触发resize事件的。 

方法二:

定时轮询 

  1. let timer = 0
  2. timer = setInterval(() => {
  3. const style = {
  4. width: getStyle(dom, 'width'),
  5. height: getStyle(dom, 'height'),
  6. };
  7. }, 200)

每过200ms,我们都进行一次dom大小的获取,从而和之前的宽高进行对比,就能知道DOM是否发生了变化。

缺点:开销太大。

方法三:

监听元素的滚动事件,在 目标 dom 里面包裹一个同等大小的 div,是隐藏不可见的,当目标 dom 大小变化时,触发滚动事件。

参考文章:巧妙监测元素尺寸变化

方法四:

MutationObserver

通过 MutationObserver 监听dom 节点变化,MutationObserver 是在DOM4规范中定义的,它的前身是 MutationEvent 事件,该事件最初在 DOM2 事件规范中介绍,到来了 DOM3 事件规范中正式定义,但是由于该事件存在兼容性以及性能上的问题被弃用;可以用它来监听 dom style 的变化

参考文章:

Mutation Observer API

JS监听div的resize事件

方法五:

ResizeObserver

  1. const resizeObserver = new ResizeObserver(entries => {
  2. for (let entry of entries) {
  3. console.log(entry.target.style.width)
  4. }
  5. });
  6. resizeObserver.observe(document.querySelector('.line-numbers'));

参考文章:用vue.js如何实时获取某个div的变化的width,并把数据展示在页面?

方法六:

IE9-10 默认支持 div 的 resize 事件,可以直接通过 div.attachEvent('onresize', handler); 的方式实现;

其它浏览器,通过在 div 中添加一个内置 object 元素实现监听,设置 object 元素的 style 使其填充满 div,这样当 div 的 size 发生变化时,object 的 size 也会发生变化,然后监听 object 元素的 contentDocument.defaultView(window对象)的 resize 事件。

参考文章:JS监听div的resize事件

项目使用分析 

第一,通过setInterval的方式进行监听DOM变化,开销较大。

第二,通过一个简单的API,监听DOM,就进行bind函数的绑定,解除一个DOM的监听,使用类似clear之类的函数解除监听。

第三,支持回调函数。

方法七:

Vue指令

参考文章:监听尺寸元素变化

方法八:

npm项目

例如:

element-resize-detector 

NPM仓库:https://www.npmjs.com/package/element-resize-detector

1、安装:

npm install element-resize-detector

2、使用 

  1. var elementResizeDetectorMaker = require("element-resize-detector")
  2. var erd = elementResizeDetectorMaker()
  3. erd.listenTo(this.$el, function (element) {
  4. var width = element.offsetWidth
  5. var height = element.offsetHeight
  6. that.$nextTick(function () {
  7. console.log("Size: " + width + "x" + height)
  8. })
  9. })

wd-domsize-monitor

参考文章

vue中监控元素大小变化element-resize-detector

vue+element项目里实时监听某个div宽度的变化,然后执行相应的事件

如何监听DOM大小的变化

js怎么监听div元素的resize

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小丑西瓜9/article/detail/223127
推荐阅读
相关标签
  

闽ICP备14008679号