在vue中使用mixin提高可复用性
一、mixin(混入)的概念
mixin是一个可以包含任意组件选项的对象
export const mixin = {
mounted() {
this.handlePlayList()
},
methods: {
handlePlayList() {
throw new Error('component must implement handlePlayList method')
}
}
}
当组件使用 混入对象时,对象中的选项将被“混合”进入组件本身的选项
也就是说,mixin对象内的各种钩子将会与组件本身的钩子进行合并
如果数据对象使用了相同的名字,则会以组件本身的数据优先
另外,混入对象的钩子将在组件自身钩子之前调用
更详细的用法 请参考官方文档
二、具体使用示例
在一个音乐播放网站的开发过程中,遇到这么一个问题:当用户开始播放音乐、且退出全屏播放后,在窗口底部将会有一个固定高度的迷你播放器
此时我们就需要对其他使用了better-scroll插件的页面进行调整
让列表能滚动到最后一项(否则会被迷你播放器遮挡住)
解决思路是这样的:
1、定义一个可复用的mixin对象
2、在mixin对象中定义相关钩子,要求组件本身必须实现一个handlePlayListMixin方法
3、在handlePlayListMixin方法中,设置列表距离页面底部的距离,并调用better-scroll的refresh方法(重新计算滚动数据)
三、代码实现
首先定义mixin对象
import {mapGetters} from 'vuex'
export const playListMixin = {
computed: {
...mapGetters([
'playList' //当前播放的歌曲列表
])
},
mounted() {
this.handlePlayList(this.playList)
},
activated() {
this.handlePlayList(this.playList)
},
watch: {
playList(newVal) {
this.handlePlayList(newVal)
}
},
methods: {
handlePlayList() {
throw new Error('component must implement handlePlayList method')
}
}
}
在组件中引入并注册mixin
并实现handlePlayListMixin方法(去覆盖mixin中的方法)
import { playListMixin } from 'xxx'
export default {
name: 'xxx',
mixins: [ playListMixin ],
methods: {
handlePlayListMixin (playList) {
const bottomVal = playList.length > 0 ? '60px' : 0
this.$refs.list.style.bottom = bottomVal
this.$refs.list.refresh()
}
}
}
ref=list 的引用是添加在已经封装好的scroll组件上的
若当前播放的歌曲列表不为空(即用户正在播放音乐)
那么混入了mixin对象的组件 就会在mounted、activated(主要针对使用了keep-alive的组件)等钩子中,调用handlePlayListMixin方法
从而调整列表距离页面顶部的距离,并令better-scroll重新计算滚动距离
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 深入理解 Mybatis 分库分表执行原理
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
· Sdcb Chats 技术博客:数据库 ID 选型的曲折之路 - 从 Guid 到自增 ID,再到
· 语音处理 开源项目 EchoSharp
· 《HelloGitHub》第 106 期
· Spring AI + Ollama 实现 deepseek-r1 的API服务和调用
· 使用 Dify + LLM 构建精确任务处理应用