• 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

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

  • 相关阅读:
    HighTec 工程配置详解
    拼搏半个月,刷了 571道Java高频面试题喜提 offer
    面试系列多线程:Tomcat线程池的原理
    Unity 内部执行cmd命令行
    移动端适配单位vw和px的转换
    利用pearcmd实现裸文件包含
    TCP案例-实时群聊
    SGM321运算放大器(1MHZ带宽增益,0.52V/us压摆率,CMOS低功耗单运放)
    我的创作纪念日
    ctf.show刷题记录_web(1-10)
  • 原文地址:https://blog.csdn.net/xh1506101064/article/details/133791543