【UniApp】-uni-app -CompositionAPI传递数据


风晓
风晓 2023-12-29 10:38:27 47619 赞同 0 反对 0
分类: 资源
了解完了uni-app-传递数据之后,这篇文章来给大家介绍一下 uni-app-CompositionAPI传递数据

搭建演示环境

创建一个全新的项目:

然后在配置一下,微信小程序的 AppId,直接去之前的项目中拷贝一下即可,找到之前项目的 manifest.json 文件,然后选择微信小程序配置,复制一下即可。

  • 经过如上的这么一顿操作之后,就可以搭建完毕运行环境,与编码环境
  • 接下来就可以开始进行介绍 uni-app-CompositionAPI传递数据内容了

步入正题

通过路径拼接传递数据

创建一个 one 页面,我们在首页当中编写一个按钮,点击按钮跳转到 one 页面,然后在 one 页面当中显示传递过来的数据,我这里是通过 CompositionAPI 来进行传递数据的,代码如下:

 
<template>
	<view>
		<button type="primary" @click="onJumpOne">跳转到One界面</button>
	</view>
</template>

<script setup>
	function onJumpOne() {
		uni.navigateTo({
			url: '/pages/one/one?name=BNTang&age=18'
		})
	}
</script>

然后在 one 页面当中接收数据,代码如下:

 
<template>
	<view>
		<text>One</text>
	</view>
</template>

<script setup>
	import {
		onLoad
	} from '@dcloudio/uni-app'

	onLoad((option) => {
		console.log(option)
	})
</script>

然后我们点击按钮,跳转到 one 页面,可以看到控制台打印出了我们传递过来的数据:

除了通过 option 来接收数据之外,我们还可以通过 props 来接收数据,代码如下:

 
<script setup>
	const props = defineProps({
		name: String,
		age: Number
	})
	console.log(props.name, props.age);
</script>

好了,这是正向传递数据,那么反向传递数据呢?

反向传递数据

我们在 one 页面当中编写一个按钮,点击按钮跳转到首页页面,然后在首页页面当中显示传递过来的数据,代码如下:

 
<template>
	<view>
		<text>One</text>
		<button type="primary" @click="goBackClick">返回首页</button>
	</view>
</template>

<script setup>
	function goBackClick() {
		uni.navigateBack({
			delta: 1
		});
	}
</script>

页面已经搭建好了,那么我们就可以开始传递数据了,在之前我们是通过 this.getOpenerEventChannel(); 来进行传递数据的,但是在 CompositionAPI 当中没有 this,那么我们现在要做的第一件事情就是获取 this,在 compositionAPI 当中获取 this 可以通过 getCurrentInstance() 来获取,代码如下:

 
<script setup>
	import {
		ref,
		getCurrentInstance
	} from 'vue'

	// 获取 this
	const $instance = ref(getCurrentInstance().proxy)

    ... other
</script>

竟然获取到了 this,那么接下来的代码就和之前的一样了,代码如下:

 
<script setup>
	import {
		ref,
		getCurrentInstance
	} from 'vue'

	// 获取 this
	const $instance = ref(getCurrentInstance().proxy)

	function goBackClick() {
		uni.navigateBack({
			delta: 1
		});
		
		const eventChannel = $instance.value.getOpenerEventChannel();
		eventChannel.emit("acceptDataFromOpenerPage", {
			data: '通过事件通道返回时传递数据'
		})
	}
</script>

如上代码就是我们之前的逆着传递数据的代码,改动的点就是之前是 this.getOpenerEventChannel(); 现在是 $instance.value.getOpenerEventChannel();,然后我们在首页当中接收数据,代码如下:

 
<script setup>
	function onJumpOne() {
		uni.navigateTo({
			url: '/pages/one/one?name=BNTang&age=18',
			events: {
				acceptDataFromOpenerPage(data) {
					console.log(data)
				}
			}
		})
	}
</script>

运行一下,点击按钮跳转到 one 页面,然后点击返回按钮,可以看到控制台打印出了我们传递过来的数据:

正向传递数据

那么逆向传递看完了,正向传递就来快速过一下,首先更改首页的代码,代码如下:

 
<script setup>
	function onJumpOne() {
		uni.navigateTo({
			url: '/pages/one/one',
			success(res) {
				// 通过eventChannel向被打开页面传送数据
				res.eventChannel.emit('acceptDataFromOpenerPage', {
					data: '通过事件通道传递的数据'
				})
			}
		})
	}
</script>

然后在 one 页面当中接收数据,代码如下:

 
<script setup>
	import {
		ref,
		getCurrentInstance
	} from 'vue'
	import {
		onLoad
	} from '@dcloudio/uni-app'

	// 获取 this
	const $instance = ref(getCurrentInstance().proxy)

	onLoad((option) => {
		const eventChannel = $instance.value.getOpenerEventChannel();
		eventChannel.on('acceptDataFromOpenerPage', function(data) {
			console.log(data)
		})
	})
</script>

运行一下,点击按钮跳转到 one 页面,可以看到控制台打印出了我们传递过来的数据:

如果您发现该资源为电子书等存在侵权的资源或对该资源描述不正确等,可点击“私信”按钮向作者进行反馈;如作者无回复可进行平台仲裁,我们会在第一时间进行处理!

评价 0 条
风晓L1
粉丝 1 资源 2038 + 关注 私信
最近热门资源
银河麒麟桌面操作系统备份用户数据  127
统信桌面专业版【全盘安装UOS系统】介绍  122
银河麒麟桌面操作系统安装佳能打印机驱动方法  114
银河麒麟桌面操作系统 V10-SP1用户密码修改  105
最近下载排行榜
银河麒麟桌面操作系统备份用户数据 0
统信桌面专业版【全盘安装UOS系统】介绍 0
银河麒麟桌面操作系统安装佳能打印机驱动方法 0
银河麒麟桌面操作系统 V10-SP1用户密码修改 0
作者收入月榜
1

prtyaa 收益393.62元

2

zlj141319 收益218元

3

1843880570 收益214.2元

4

IT-feng 收益209.03元

5

风晓 收益208.24元

6

777 收益172.71元

7

Fhawking 收益106.6元

8

信创来了 收益105.84元

9

克里斯蒂亚诺诺 收益91.08元

10

技术-小陈 收益79.5元

请使用微信扫码

加入交流群

请使用微信扫一扫!