vue 如何制作一个跟随窗口大小变化而变化的组件
像下图中展示的那些统计数件就是跟随窗口变化而变化的,而且是几乎等比缩放的。
实现原理
只简略说一下原理。
- pinia 中记录一个窗口变化的高度值
- 给要变化的组件添加一个高度值
- 组件内部所有关于长度距离的值都通过这个传递的值生成
比如下面这个例子中的所有长度值都通过传递的唯一长度值 props.height
来生成
<template><div :class="['home-count-up', type, {'shadow': hasShadow}]" @click="routeToPath":style="`width: ${props.height * 2.5}px;padding: ${props.height * 5/ 50}px ${props.height * 13/ 50}px;border-radius: ${props.height * 6 / 50}px`"><div class="icon"><el-icon :size="props.height * 4 / 10" fill="black"><component :is="icon"/></el-icon></div><div class="content"><div class="label" :style="`font-size: ${props.height * 7 / 50}px`">{{label}}</div><CountUp class="value" :font-size="props.height * 15 / 50" :endVal="value"/></div></div>
</template>
这里有一个技巧:
当多个组件都需要跟 window.onresize 进行绑定时,可以这样写,就会同时触发多个:
window.addEventListener('resize', () => {this.width = this.widthInitthis.height = this.heightInitthis.$nextTick(()=>{this.resize()})
})
下面这样就只能触发一个
window.onresize = () => {this.width = this.widthInitthis.height = this.heightInitthis.$nextTick(()=>{this.resize()})
}