vue监听dom元素的宽高变化和自定义指令监听dom元素的宽高变化

在Vue中,你可以使用ResizeObserver来监听DOM元素的宽高变化。以下是一个示例代码:

html 复制代码
<template>
  <div ref="myElement" @resize="handleResize">
    <!-- DOM元素内容 -->
  </div>
</template>

<script>
export default {
  mounted() {
    const resizeObserver = new ResizeObserver((entries) => {
      // 当DOM元素的宽高发生变化时执行回调函数
      this.handleResize(entries[0].contentRect);
    });
    resizeObserver.observe(this.$refs.myElement);

    // 组件销毁时停止观察
    this.$once("hook:beforeDestroy", () => {
      resizeObserver.disconnect();
    });
  },
  methods: {
    handleResize(rect) {
      // 在这里处理DOM元素宽高变化后的逻辑
      console.log(`宽度:${rect.width}px,高度:${rect.height}px`);
    },
  },
};
</script>

以上示例演示了如何在Vue组件中通过ResizeObserver来监听DOM元素的宽高变化。在mounted钩子中创建ResizeObserver实例,并通过$refs访问DOM元素进行观察。当宽高变化时,会调用handleResize方法进行处理。

另外,你也可以创建一个自定义指令来监听DOM元素的宽高变化。以下是一个自定义指令的示例代码:

html 复制代码
<template>
  <div v-resize="handleResize">
    <!-- DOM元素内容 -->
  </div>
</template>

<script>
export default {
  directives: {
    resize: {
      inserted(el, binding) {
        const resizeObserver = new ResizeObserver((entries) => {
          // 当DOM元素的宽高发生变化时执行回调函数
          binding.value(entries[0].contentRect);
        });
        resizeObserver.observe(el);

        // 组件销毁时停止观察
        el._resizeObserver_ = resizeObserver;
      },
      unbind(el) {
        if (el._resizeObserver_) {
          el._resizeObserver_.disconnect();
          delete el._resizeObserver_;
        }
      },
    },
  },
  methods: {
    handleResize(rect) {
      // 在这里处理DOM元素宽高变化后的逻辑
      console.log(`宽度:${rect.width}px,高度:${rect.height}px`);
    },
  },
};
</script>

以上示例演示了如何创建一个自定义指令v-resize,它通过ResizeObserver来监听绑定指令的DOM元素的宽高变化。当宽高变化时,会调用指令绑定值所指定的方法handleResize进行处理。

希望以上代码示例对你有所帮助!

相关推荐
夜焱辰1 小时前
浏览器端 Agent 的文件版本管理:不用 Git,基于 OPFS + SQLite 自己造了一个
前端·人工智能
梦想的颜色1 小时前
TypeScript 完全指南(下):从类型体操到生产级配置
前端·javascript·typescript
Hi~晴天大圣2 小时前
npm使用介绍
前端·npm·node.js
888CC++3 小时前
如何在 C 语言中进行程序调试?
前端·javascript·算法
喵个咪3 小时前
基于 Taro 的 Headless CMS 多端前端架构:技术解析与二次开发导引
前端·react.js·taro
狂炫冰美式3 小时前
你还在古法PPT吗,试试HTML呢?免费编辑导出工具给 xdm 放这了
前端·后端·github
万少4 小时前
未来组织的分水岭不是员工数量,而是人才密度
前端·后端·面试
任磊abc4 小时前
nextjs16配置eslint+prettier
前端·eslint·nextjs·prettier
x***r1514 小时前
Another-Redis-Desktop-Manager.1.3.7安装步骤详解(附Redis可视化连接与Key管理教程)
前端·bootstrap·html
Captaincc4 小时前
你真的知道自己把 AI 用在了哪里吗?这是 Vibe Usage 想回答的问题
前端·vibecoding