vue3自定義指令自動獲取節(jié)點的width和height代碼示例
前言
想寫一個依賴庫, 但是需要監(jiān)聽組件的width和height這些數(shù)據(jù), 就找到了ResizeObserver這個方法,不想每次使用的時候都要創(chuàng)建和銷毀 ResizeObserver, 索性就直接封裝成為一個指令用來獲取想要的信息,
ResizeObserver對象上能夠獲取的信息還是非常多的, 除了width, height 還有 top, bottom, left, top等, 需要使用到這些可以到MDN去查看他的使用方法
實現(xiàn)效果當元素大小發(fā)生改變時,會自動更新width 和height 的值

一. 環(huán)境
"vue": "^3.4.29"
二. 代碼
文件ResizeObserverStore.ts
class ResizeObserverStore {
// 存儲目標元素和對應的ResizeObserver實例
observer= new Map<HTMLElement, ResizeObserver[]>();
// 獲取目標元素對應的ResizeObserver實例
get(target: HTMLElement) {
return this.observer.get(target) || [];
}
// 設置目標元素對應的ResizeObserver實例
set(target: HTMLElement, observer: ResizeObserver) {
const observers = this.observer.get(target);
if (observers) {
observers.push(observer);
} else {
this.observer.set(target, [observer]);
}
};
// 銷毀目標元素對應的ResizeObserver實例
remove(target: HTMLElement) {
const observers = this.observer.get(target);
// 銷毀事件
if (observers) {
observers.forEach(observer => {
observer.disconnect();
});
this.observer.delete(target);
}
}
}
// 創(chuàng)建一個ResizeObserverStore實例
const resizeObserverStore = new ResizeObserverStore();
// 使用ResizeObserver監(jiān)聽目標元素的變化
export const useResizeObserver = (target: HTMLElement, callback: ResizeObserverCallback) => {
const observer = new ResizeObserver(callback);
observer.observe(target);
resizeObserverStore.set(target, observer);
return observer;
}
// 移除ResizeObserver監(jiān)聽
export const removeResizeObserver = (target: HTMLElement) => {
resizeObserverStore.remove(target);
}
文件: directives.ts
import {App, Directive} from "vue";
import {removeResizeObserver, useResizeObserver} from "ResizeObserverStore.ts";
export const vSize: Directive = {
mounted: (el, binding) => {
// 注冊并使用resizeObserver
useResizeObserver(el, (entries) => {
binding.value.width = entries[0].contentRect.width
binding.value.height = entries[0].contentRect.height
})
},
beforeUnmount: (el) => {
// 銷毀resizeObserver
removeResizeObserver(el)
},
}
export default (app: App)=>{
app.directive('size', vSize)
}
該指令主要使用ResizeObserver對象,它可以用于監(jiān)聽元素邊界尺寸的大小。
三. 使用 (全局 或 局部 使用都可以)
1. 全局注冊
文件: main.ts
import {createApp} from "vue";
import App from "./App.vue";
import directives from "../directives";
const app = createApp(App)
// 在這里注冊以下就可以使用了
directives(app)
app.mount("#app");
2. 局部使用
<template>
<div class="layout-box" v-size="size"></div>
</template>
<script setup lang="ts">
import {reactive, ref, watch, watchEffect} from "vue";
// 如果全局引入的話就不用在這里引用了
import {vSize} from "../directives";
const size = reactive({
width: 0,
height: 0
})
watchEffect(
() => {
console.log(size.width, size.height)
}
)
</script>
<style lang="scss" scoped>
.layout-box{
width: 100px;
height: 100px;
background-color: #f5f5f5;
border: 1px solid #bd34fe;
overflow: auto;
resize: both;
}
</style>總結
到此這篇關于vue3自定義指令自動獲取節(jié)點的width和height的文章就介紹到這了,更多相關vue3自動獲取節(jié)點的width和height內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
一篇文章帶你使用Typescript封裝一個Vue組件(簡單易懂)
這篇文章主要介紹了使用Typescript封裝一個Vue組件,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-06-06
基于vue-cli3多頁面開發(fā)apicloud應用的教程詳解
這篇文章主要介紹了基于vue-cli3多頁面開發(fā)apicloud應用,本文采用vue-cli+APIcloud的方式寫解決以上痛點,開發(fā)靈活,并且打包之后體積更小速度更快,需要的朋友可以參考下2019-06-06

