uniapp中mixins的使用

mixins 是一个 js 对象,它可以包含我们组件中JS部分的任意功能选项,如:data、components、methods、created、computed 等等。我们只要将公用的功能以对象的方式传入 mixins 选项中,当组件使用 mixins 对象时所有 mixins 对象都将被混入该组件中。

一、创建mixins 页面

在项目根目录下创建mixins目录,放入一个 tabbar-badge.js

javascript 复制代码
import { mapGetters } from 'vuex'

export default {
	computed: {
		...mapGetters('m_cart', ['total'])
	},
	onShow() {
        // 第一次打开页面就显示 tabber 的上标
		this.setBadge()
	},
	methods: {
		setBadge() {
			uni.setTabBarBadge({
                //第三个tabber的上标
				index: 2,
                // tabber的上标只能是字符串
				text: this.total + ''
			})
		}
	}
}

二、在页面中引用 mixins

使用时只需要导入页面,然后挂载 mixins 为组件

javascript 复制代码
    import badgeMix from '@/mixins/tabbar-badge.js'
	export default {
		mixins: [badgeMix],
		data() {
			return {
			};
		}
    }

三、注意点

1、引用 mixins 的页面如果改变 mixins 的数据,只会在当前页面生效,不会影响到其它引用 mixins 的页面

2、值为对象(components、methods 、computed、data)时,如果当前页面和 mixins 存在同名,则页面中的(components、methods 、computed、data)覆盖 mixins 中相同的对象

3、值为钩子函数(created、mounted)时,则 mixins 中的钩子函数先调用,当前页面中后调用

4、当 mixins 里面包含异步请求函数,如果想在页面中获取结果,需要返回异步函数,不能只返回结果

四、和vuex的区别

vuex: 用来做状态管理的,里面定义的变量在每个组件中均可以使用和修改,修改变量会影响所有引用的组件
Mixins: 可以定义共用的变量,在每个组件中使用,引用组件中之后,各个变量是相互独立的,值的修改只影响当前组件,不会影响其它组件

相关推荐
2501_933907211 天前
宁波小程序公司提供专业的小程序开发服务
科技·微信小程序·小程序
2501_915918411 天前
iOS App 拿不到数据怎么办?数据解密导出到分析结构方法
android·macos·ios·小程序·uni-app·cocoa·iphone
2501_916008891 天前
iOS App 抓包看不到内容,从有请求没数据一步步排查
android·ios·小程序·https·uni-app·iphone·webview
扶苏10021 天前
记一次 uni-app开发微信小程序 textarea 的“伪遮挡”踩坑实录
微信小程序·小程序·uni-app
RuoyiOffice2 天前
企业请假销假系统设计实战:一张表、一套流程、两段生命周期——BPM节点驱动的表单变形术
java·spring·uni-app·vue·产品运营·ruoyi·anti-design-vue
KongHen022 天前
uniapp-x实现自定义tabbar
前端·javascript·uni-app·unix
哈罗哈皮2 天前
trea也很强,我撸一个给你看(附教程)
前端·人工智能·微信小程序
毕设源码-赖学姐2 天前
【开题答辩全过程】以 居家养老服务微信小程序设计与实现为例,包含答辩的问题和答案
微信小程序·小程序
RuoyiOffice2 天前
SpringBoot+Vue3+Uniapp实现PC+APP双端考勤打卡设计:GPS围栏/内网双模打卡、节假日方案、定时预生成——附数据结构和核心源码讲解
java·spring·小程序·uni-app·vue·产品运营·ruoyi
2501_915921432 天前
2026 iOS 上架新趋势 iOS 发布流程模块化
android·ios·小程序·https·uni-app·iphone·webview