uniapp 使用 $emit和$on——$on中无法为data中的变量赋值

问题在于this的指向,

解决办法是使用变量保存$on,其次再为data中的值赋值

以下是具体代码:

1、html代码:

c 复制代码
			<view class="form_picker" @click="selePositionFun()">
				<view class="">
					<input placeholder="请选择职位类别" :disabled="true" v-if="positionOne == ''" />
					<view class="" v-else>{{positionOne}}-{{positionTwo}}</view>
				</view>
			</view>

2、 js代码:

①传递对象:
c 复制代码
A页面传递:(使用.$emit)
	let newarr = {
		one:this.leftList[this.tabindex].type,   //一级名称
		two:this.selectList[0]                   //二级名称
	}
	uni.$emit('positionOne',newarr)
	uni.navigateBack()

B页面接收:(使用.$on)
	onShow() {
		//接收上个页面传递的职位类别
		const on = uni.$on('positionOne', function (data) {
		 console.log('打印data', Object.values(data))    // ["销售", "广告销售"]
			var list = Object.values(data)   //使用Object.values 将对象转换为数组
			this.positionOne = list[0]
			this.positionTwo = list[1]
		})
		//再次赋值
		this.positionOne = on.positionOne
		this.positionTwo = on.positionTwo
			
		console.log('打印111', this.positionOne)   //销售 
		console.log('打印222', this.positionTwo)   //广告销售
	},
②传递数组:
c 复制代码
A页面传递:(使用.$emit)
	uni.$emit('selectList', this.selectList)   //传递选中的数组
	uni.navigateBack()

B页面接收:(使用.$on)
	onShow() {
		//接收上个页面传递的职位类别
		const on = uni.$on('selectList', function(data) {
			// console.log('打印收到的类型',typeof(data))  //object
			this.positionTwo = data.toString() //转为字符串使用
		})
		this.positionTwo = on.positionTwo
		console.log('打印positionTwo', this.positionTwo)   //销售, 广告销售
	},

完成~

相关推荐
代钦塔拉几秒前
第二篇:VS2019 + Qt5.9.9 中文乱码实战:源码GB2312不乱码、文件写入与跨平台方案
开发语言·qt
.小小陈.29 分钟前
Linux 多线程进阶:线程互斥、同步、线程池、死锁与线程安全、读写锁、自旋锁
linux·开发语言·c++
lingran__37 分钟前
C++入门基础
开发语言·c++
吃好睡好便好1 小时前
Matlab中三种三维图的对比
开发语言·人工智能·学习·算法·matlab·信息可视化
Highcharts.js1 小时前
无需搭建数据管道,如何快速上线投资基金筛选器?
开发语言·javascript·react.js·前端框架·highcharts
雨落在了我的手上1 小时前
初识java(六):方法的使用
java·开发语言
kyriewen1 小时前
我让AI替我写Git提交信息,老板以为我每天工作16小时
前端·javascript·git
如竟没有火炬1 小时前
至少有K个重复字符的最长子串
开发语言·数据结构·python·算法·leetcode·动态规划
接着奏乐接着舞1 小时前
react native expo打包
javascript·react native·react.js
三品吉他手会点灯2 小时前
C语言学习笔记 - 32.嵌入式C语言学习阶段对初学编程者的建议
c语言·开发语言·笔记·学习