uniapp 做项目页面通讯踩的坑,反思和总结

首先,先学习一下官网的页面通讯:

1.uni.$emit(eventName,OBJECT)

属性类型描述
eventNameString事件名
OBJECTObject触发事件携带的附加参数
	uni.$emit('update',{msg:'页面更新'})
	//update 是触发的事件名,第二参数是携带的参数名。
	//触发全局的自定义事件。附加参数都会传给监听器回调。
	//反思总结:
		1.这里的update事件名不要写死,最好由外面使用的人传进来,这样别人也不用看里面绑定的事件名,直接自己写名字,自己调名字。
		2.这里携带出去的数据最好是一个对象,不要为了一个功能需要什么就返什么,因为后期很可能用到其他字段。
		3.相同事件名,后期很可能不同地方都需要调用到,这会触发很多地方的事件

2.uni.$on(eventName,callback)

属性类型描述
eventNameString事件名
callbackFunction事件的回调函数
	uni.$on('update',function(data){
		console.log('监听到事件来自 update ,携带参数 msg 为:' + data.msg);
	})
//监听全局的自定义事件。事件可以由 uni.$emit 触发,回调函数会接收所有传入事件触发函数的额外参数。
//第一个参数上面emit里面绑定的事件名,第二个参数是个回调函数
//反思总结:
	1.一定要记得销毁!!!不销毁,会导致重复触发。

另外还有两个Api一同记录

3.uni.$once(eventName,callback)

属性类型描述
eventNameString事件名
callbackFunction事件的回调函数
	uni.$once('update',function(data){
		console.log('监听到事件来自 update ,携带参数 msg 为:' + data.msg);
	})
//	监听全局的自定义事件。事件可以由 uni.$emit 触发,但是只触发一次,在第一次触发之后移除监听器。

4.uni.$off([eventName, callback])

属性类型描述
eventNameArray<String>事件名
callbackFunction事件的回调函数

说明:

如果没有提供参数,则移除所有的事件监听器;
如果只提供了事件,则移除该事件所有的监听器;
如果同时提供了事件与回调,则只移除这个回调的监听器;
提供的回调必须跟$on的回调为同一个才能移除这个回调的监听器;

	<script>
		export default {
			data() {
				return {
					
				}
			},
			mounted(){
				uni.$on('customDeptLog',this.selectedDept);
				uni.$on('customStaffLog',this.selectedStaff);
	        },
			beforeDestory(){
				uni.$off('customDeptLog',this.selectedDept)
				uni.$off('customStaffLog',this.selectedStaff)
			},
			methods: {
				selectedDept(res){
					console.log(res)
				},
				selectedStaff(res){
					console.log(res)
				},
			}
		}
	</script>

	<style>
		.content {
			display: flex;
			flex-direction: column;
			align-items: center;
			justify-content: center;
		}

		.data {
			text-align: center;
			line-height: 40px;
			margin-top: 40px;
		}

		button {
			width: 200px;
			margin: 20px 0;
		}
	</style>


注意事项

uni.$emit、 uni.$on 、 uni.$once 、uni.$off 触发的事件都是 App 全局级别的,跨任意组件,页面,nvue,vue 等
使用时,注意及时销毁事件监听,比如,页面 onLoad 里边 uni.$on 注册监听,onUnload 里边 uni.$off 移除,或者一次性的事件,直接使用 uni.$once 监听
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue 是一个用于构建用户界面的渐进式 JavaScript 框架,它主要用于开发单页面应用程序 (SPA)。Vue 提供了一种简单、灵活且高效的方式来构建交互式的 Web 界面。 UniApp 是一个基于 Vue.js 的跨平台开发框架,它可以同时使用 Vue 的语法和 API 来开发多个平台的应用程序,包括小程序、H5、App 等。UniApp 提供了一套统一的开发语法和组件库,可以在不同平台上共享代码和逻辑,大大提高了开发效率。 使用 Vue 和 UniApp 开发项目有以下优势: 1. 统一开发语法和组件库:使用 Vue 和 UniApp,你可以通过一套统一的语法和组件库来开发不同平台的应用程序,避免了学习多个框架或语言的繁琐。 2. 跨平台支持:UniApp 支持多个平台,包括微信小程序、支付宝小程序、H5 网页、App 等。你可以使用相同的代码和逻辑来开发不同平台的应用,减少了重复工作。 3. 高效开发:Vue 和 UniApp 都提供了丰富的工具和生态系统,使得开发更加高效。你可以使用 Vue 的响应式数据绑定、组件化开发等特性,快速构建复杂的应用程序。 4. 自定义扩展:由于基于 Vue,你可以使用 Vue 的插件和库来扩展 UniApp 的功能。Vue 生态系统非常丰富,有大量的插件和库可供选择,可以满足各种开发需求。 总而言之,使用 Vue 和 UniApp 可以让你更加方便地开发跨平台的应用程序,提高开发效率并节省开发成本。同时,你可以借助 Vue 和 UniApp 的强大功能和生态系统来构建出功能丰富的应用程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值