• vue3 封装自定义指令,监听元素宽高的变化


    最近做一个项目,涉及到echart图,要去根据父元素去自适应宽高,所以需要监听到元素的宽高变化、

    因为是监听某一元素的宽高变化,所以这里用的是ResizeObserver.

    ResizeObserver是可以监听到DOM元素,宽高的变化,需要注意的一点就是监听出变化结果是contentBox的宽度和高度。

    以下为浏览器兼容性

    在这里插入图片描述

    第一步:封装自定义指令

    在directive文件夹下创建一个resizeObserver.js文件
    内容如下

    // 监听元素大小变化的指令
    const map = new WeakMap()
    const ob = new ResizeObserver((entries) => {
        for (const entry of entries) {
            // 获取dom元素的回调
            const handler = map.get(entry.target)
            //存在回调函数
            if (handler) {
                // 将监听的值给回调函数
                handler({
                    width: entry.borderBoxSize[0].inlineSize,
                    height: entry.borderBoxSize[0].blockSize
                })
            }
        }
    })
    
    
    export const Resize = {
    
        mounted(el, binding) {
            //将dom与回调的关系塞入map
            map.set(el, binding.value)
            //监听el元素的变化
            ob.observe(el)
        },
        unmounted(el) {
            //取消监听
            ob.unobserve(el)
        }
    }
    
    export default Resize
    
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35

    第二步:在directive文件夹再创建一个index.js文件,目的是为了集中注册自定义指令

    import { Resize } from "./resizeObserver"
    
    
    // 自定义指令集合
    const directives = {
        Resize,
    }
    
    export default {
        install(app) {
            Object.keys(directives).forEach((key) => {
                app.directive(key, directives[key])
            })
        }
    }
    
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    第三步:在main.js文件进行全局注册

    import directives from "@/util/directive/index"
    app.use(directives)
    
    • 1
    • 2

    第四步:使用方法

    
    
    
    
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    以上,希望大家一键三连哇~~ 感谢

  • 相关阅读:
    OpenHarmony Axios组件使用过程中,Api9不适配问题
    Spring Boot使用WebSocket模拟聊天
    【leetcode】 数组二分查找
    酷睿处理器型号前面的字母代表什么
    PyQt5快速开发与实战 8.6 设置样式
    C++模拟实现string类
    AcWing:3498. 日期差值
    【机器学习】039_合理初始化
    五步骤清理,形成自己的喜悦系统
    STM32+2.9inch微雪墨水屏(电子纸)实现显示
  • 原文地址:https://blog.csdn.net/xh1506101064/article/details/133791543