use-dom-resize.js 646 B

123456789101112131415161718192021222324
  1. import { onMounted, onUnmounted } from 'vue'
  2. export const useObserveDomResize = (container, cb) => {
  3. onMounted(() => {
  4. const domList = [].concat(container()) // 同时支持数组及单个容器
  5. const cbList = [].concat(cb)
  6. const resizeObserver = new ResizeObserver((entries) => {
  7. entries.forEach((entry, i) => {
  8. const cb = cbList[i]
  9. if (cb && typeof cb === 'function') {
  10. cb(entry)
  11. }
  12. })
  13. }, 200, true)
  14. // 开启监听
  15. domList.forEach((dom) => {
  16. resizeObserver.observe(dom)
  17. })
  18. onUnmounted(() => {
  19. // 销毁
  20. resizeObserver.disconnect()
  21. })
  22. })
  23. }