uniapp中使用uni.$emit和uni.$on在vue和nvue页面之间传值但是无法赋值的问题

背景:我们在vue页面和nvue页面之间进行传值可以使用uni.emit和uni.onsh事件监听实现,官网描述:uni-app官网 (dcloud.net.cn)https://uniapp.dcloud.net.cn/api/window/communication.html#emit

而且官网上也明确说明了:

一、问题:vue页面->nvue页面传值无法赋值

在使用这个的时候碰到了问题,就是**说vue页面->nvue页面传值,在nvue页面无法通过this.xxx=data这样赋值给nvue页面的data数据,**很奇怪。

二、解决:

2.1设置延迟

在vue页面:(在这个页面设置延迟)

在nvue页面:

2.2设置参数在本地缓存main.js里面

但是一有这个情况不可能全放进去,不太现实

2.3嵌套使用

思路:在你使用emit的页面使用1个on嵌套 然后去你想on接收的页面触发上面1个on的事件(这个方法是网上找的,大佬说可以实现,我没试过。)

复制代码
onUnload() {
	uni.$off('need');
},
methods: {
	price: function(id) {
		uni.$on('need',()=>{
			uni.$emit('price', {
				msg:'传参' 
			})
		});
        }
}

onLoad() {
	uni.$on('price',(res)=>{
		this.msg = res.msg;
	});
	uni.$emit('need');
},
onUnload() {
	uni.$off('price');
}

补充:在研究这个情况的时候,曾一度以为是this指向出现问题,其不再指向当前Vue

实例而是指向别处导致无法赋值,如果上面的方法不行可以看看是否this指向问题。

三、nvue页面->vue页面传值

没有测试,但网上查到有说直接接可以正常显示传递的数据

四、nvue页面->nvue页面传值

自己使用可以正常传递并赋值

相关推荐
2501_915918412 天前
TCP 抓包分析在复杂网络问题中的作用,从连接和数据流层面理解系统异常行为
网络·网络协议·tcp/ip·ios·小程序·uni-app·iphone
じòぴé南冸じょうげん2 天前
APP本地调试正常,但是打包后出现账号密码解析错误,且前端未使用加密解密
小程序·uni-app·web app
快起来搬砖了2 天前
UniApp 路由配置实战:从全局守卫到 404 页面优雅处理
uni-app
5335ld2 天前
uniapp-APP端table列表左侧第一列固定、头部固定
windows·uni-app
一个假的前端男2 天前
uni-app App 端长按录音的工程级实现
uni-app
无名前端小白2 天前
uniapp 安卓离线打包, 无法调起系统安装应用
uni-app
游戏开发爱好者82 天前
苹果 App 上架流程,结合 Xcode、CI 等常见工具
macos·ios·ci/cd·小程序·uni-app·iphone·xcode
2501_915106322 天前
用 HBuilder 上架 iOS 应用时如何管理Bundle ID、证书与描述文件
android·ios·小程序·https·uni-app·iphone·webview
2501_915909062 天前
资源文件混淆在 iOS 应用安全中的实际价值
android·安全·ios·小程序·uni-app·iphone·webview
2501_915918412 天前
iOS App 性能测试中常被忽略的运行期问题
android·ios·小程序·https·uni-app·iphone·webview