feat: 首页图表添加resize自适应
This commit is contained in:
67
src/utils/resize.ts
Normal file
67
src/utils/resize.ts
Normal file
@@ -0,0 +1,67 @@
|
||||
|
||||
import { ref } from 'vue'
|
||||
export default function() {
|
||||
const chart = ref<any>()
|
||||
const sidebarElm = ref<Element>()
|
||||
|
||||
const chartResizeHandler = () => {
|
||||
if (chart.value) {
|
||||
chart.value.resize()
|
||||
}
|
||||
}
|
||||
|
||||
const sidebarResizeHandler = (e: TransitionEvent) => {
|
||||
if (e.propertyName === 'width') {
|
||||
chartResizeHandler()
|
||||
}
|
||||
}
|
||||
|
||||
const initResizeEvent = () => {
|
||||
window.addEventListener('resize', chartResizeHandler)
|
||||
}
|
||||
|
||||
const destroyResizeEvent = () => {
|
||||
window.removeEventListener('resize', chartResizeHandler)
|
||||
}
|
||||
|
||||
const initSidebarResizeEvent = () => {
|
||||
sidebarElm.value = document.getElementsByClassName('sidebar-container')[0]
|
||||
if (sidebarElm.value) {
|
||||
sidebarElm.value.addEventListener('transitionend', sidebarResizeHandler as EventListener)
|
||||
}
|
||||
}
|
||||
|
||||
const destroySidebarResizeEvent = () => {
|
||||
if (sidebarElm.value) {
|
||||
sidebarElm.value.removeEventListener('transitionend', sidebarResizeHandler as EventListener)
|
||||
}
|
||||
}
|
||||
|
||||
const mounted = () => {
|
||||
initResizeEvent()
|
||||
initSidebarResizeEvent()
|
||||
}
|
||||
|
||||
const beforeDestroy = () => {
|
||||
destroyResizeEvent()
|
||||
destroySidebarResizeEvent()
|
||||
}
|
||||
|
||||
const activated = () => {
|
||||
initResizeEvent()
|
||||
initSidebarResizeEvent()
|
||||
}
|
||||
|
||||
const deactivated = () => {
|
||||
destroyResizeEvent()
|
||||
destroySidebarResizeEvent()
|
||||
}
|
||||
|
||||
return {
|
||||
chart,
|
||||
mounted,
|
||||
beforeDestroy,
|
||||
activated,
|
||||
deactivated
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user