Resize observer directive for vue 3.0
Modern browsers
# yarn
yarn add @vue-toys/resize-observer
# or npm
npm install @vue-toys/resize-observer
in main.js
or main.ts
import { createApp } from 'vue'
import ResizeObserver from '@vue-toys/resize-observer'
import App from './App.vue'
const app = createApp(App)
app.use(Resize)
app.mount('#app')
in .vue
file template
<template>
<div v-resize="handleResize">
Hello world!
</div>
</template>
<script>
export default {
methods: {
handleResize({ width, height, offsetWidth, offsetHeight }) {
console.log({ width, height, offsetWidth, offsetHeight })
}
}
}
</script>
in .tsx
file
import { defineComponent, h, resolveDirective, withDirectives } from 'vue'
import { Size } from '@vue-toys/resize-observer'
const handleResize = (e: Size) => {
console.log(e)
}
export default defineComponent({
render() {
const vDemo = resolveDirective('resize')
return withDirectives(h('div'), [[vDemo, handleResize]])
},
})
in .vue
file template
<template>
<div v-resize="handleResize">
Hello world!
</div>
</template>
<script>
import ResizeObserver from '@vue-toys/resize-observer';
export default {
directives: {
resize: ResizeObserver.directive,
},
methods: {
handleResize({ width, height, offsetWidth, offsetHeight }) {
console.log({ width, height, offsetWidth, offsetHeight })
}
}
}
</script>
in .tsx
file
import { defineComponent, h, resolveDirective, withDirectives } from 'vue'
import ResizeObserver, { Size } from '@vue-toys/resize-observer'
const handleResize = (e: Size) => {
console.log(e)
}
export default defineComponent({
render() {
const vDemo = ResizeObserver.directive
return withDirectives(h('div'), [[vDemo, handleResize]])
},
})
use @vue/test-utils
to test.