Vue中 引入使用 element-resize-detector 监听 Dom 元素 宽度、高度 变化

简介: Vue中 引入使用 element-resize-detector 监听 Dom 元素 宽度、高度 变化

1. 前言

很多做pc端平台的小伙伴都遇到过这样一个问题:在做侧边栏菜单时会有一个收缩和展开的一个功能,在伸缩的过程中右边的页面的宽度就会随之改变。我上网查了查 ,也动手试了试 window.onresize = ()=>{}。却不尽人意,因为它只能检测浏览器大小的变化,完全跟我们的需求不沾边。为解决类似此问题,我们可使用 element-resize-detector。

1ecd1b2606ed46e9956a89f231c9802c.png

安装及相关文档

npm i element-resize-detector

element-resize-detector npm 地址

image.png

注意事项

  • 如果元素具有 position:static,它将更改为 position:relative。因此,将应用任何无意的 top / right / bottom / left / z-index 样式,并且绝对定位的子项将相对于元素定位。
  • 隐藏元素将作为元素的直接子元素注入。

全局引入

// main.js (组件中按需引入方式,见2.使用方法中代码)
import ElementResizeDetectorMaker from "element-resize-detector";
Vue.prototype.$erd = ElementResizeDetectorMaker();

2. 使用方法

<template>
  <div class="wrap">
    <div 
      class="left" 
      :style="{width:`${leftWidth}`}">
      <button @click="changeWidth">changeWidth</button>
    </div>
  </div>
</template>
<script>
export default {
  data() {
    return {
      leftWidth:'70%',
    };
  },
  methods:{
    changeWidth(){
      this.leftWidth == '70%' ? this.leftWidth = '50%' : this.leftWidth = '70%';
    },
  },
  mounted() {
    cons elementResizeDetectorMaker = require("element-resize-detector");
    let erd = elementResizeDetectorMaker();
    erd.listenTo(document.querySelector(".left"), (ele) => {
      console.log(ele,ele.offsetWidth,ele.offsetHeight)
    });
  },
};
</script>
<style scoped lang="scss">
.left{
  height: 200px;
  background-color: pink;
}
</style>

20201204182323419.gif

相关文章
|
4月前
|
JavaScript API
vue使用hook:声明周期来监听子组件的声明周期
本文介绍了如何在Vue中使用生命周期钩子来监听子组件的生命周期事件,包括在子组件内部监听和在父组件中监听子组件的生命周期钩子。
63 0
|
5月前
|
JavaScript 开发者
[译] 监听第三方 Vue 组件的生命周期钩子
[译] 监听第三方 Vue 组件的生命周期钩子
|
4月前
|
JavaScript
在 Vue.js 中使用 watch 来监听对象属性的变化
在 Vue.js 中使用 watch 来监听对象属性的变化
|
3月前
|
JavaScript 索引
vue 在 v-for 时给每项元素绑定事件
在 Vue 中使用 v-for 渲染列表时,可以通过给每项元素绑定事件来实现交互功能。通常使用 `@click` 等事件修饰符,结合方法或内联表达式来处理事件。例如:`&lt;li v-for=&quot;item in items&quot; @click=&quot;handleClick(item)&quot;&gt;{{ item }}&lt;/li&gt;`。
|
3月前
|
JavaScript
在Vue中获取DOM元素的实际宽高
【10月更文挑战第2天】
438 1
|
3月前
|
缓存 JavaScript
|
3月前
|
JavaScript
vue3,使用watch监听props中的数据
【10月更文挑战第3天】
2197 2
|
4月前
|
JavaScript 前端开发
react字符串转为dom标签,类似于Vue中的v-html
本文介绍了在React中将字符串转换为DOM标签的方法,类似于Vue中的`v-html`指令,通过使用`dangerouslySetInnerHTML`属性实现。
125 0
react字符串转为dom标签,类似于Vue中的v-html
|
4月前
|
开发框架 JavaScript 前端开发
手把手教你剖析vue响应式原理,监听数据不再迷茫
该文章深入剖析了Vue.js的响应式原理,特别是如何利用`Object.defineProperty()`来实现数据变化的监听,并探讨了其在异步接口数据处理中的应用。
|
JavaScript 测试技术 容器
Vue2+VueRouter2+webpack 构建项目
1). 安装Node环境和npm包管理工具 检测版本 node -v npm -v 图1.png 2). 安装vue-cli(vue脚手架) npm install -g vue-cli --registry=https://registry.
1067 0