resize-observer-polyfill的使用 vue监听页面元素变化

文章介绍了如何在Vue项目中安装并使用resize-observer-polyfill库来监听DOM元素的宽高变化。通过创建一个名为listenDomChange的函数,实现了对目标节点的尺寸变化进行节流处理的回调。在组件中,将这个功能应用到一个div元素上,当容器的高度变化时,会触发reSizeMap函数更新地图的宽高。
摘要由CSDN通过智能技术生成

1、安装resize-observer-polyfill

npm install resize-observer-polyfill --save-dev

2、在utils文件夹下的index.ts引入使用

import ResizeObserver from 'resize-observer-polyfill'
/**
 * @description 监听dom的宽高变化
 * @param {ElementDom} targetNode 需监听的dom
 * @param {Function} throttleTime 监听的频率
 * @param {Number} callback 回调函数
 * @returns resizeObserver
 */
export const listenDomChange = function (targetNode: Element, callback: any, throttleTime = 300) {
  const _callback = throttle(callback, throttleTime)
  const observer = new ResizeObserver(_callback)
  observer.observe(targetNode)
  return observer
}

3、组件内使用

<template>
  <div class="mapContainer container" ref="mapContainer">高度变化</div>
</template>
<script lang="ts" setup>
import { listenDomChange } from '@/utils'

const mapContainer = shallowRef<HTMLDivElement | null>(null)
onMounted(function () {
  listenMapChange()
})

/**
 * @description 监听容器宽高的变化
 */
const listenMapChange = function () {
  const targetNode = mapContainer.value
  // 观察器的配置
  listenDomChange(targetNode!, () => {
    reSizeMap()
  })
}
/**
 * @description 更新地图的宽高
 */
const reSizeMap = () => {
  console.log('高度变化', mapContainer.value?.clientHeight)
}

</script>
<style lang="scss" scoped>
.mapContainer {
  width: 100%;
  height: calc(100vh - 80px);
  position: relative;
  z-index: 10;
}
</style>

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值