uni-app页面数据传参方式

简介: uni-app页面数据传参方式

uni-app 是一个使用 Vue.js 开发所有前端应用的框架,可以编译到 iOS、Android、H5、小程序等多个平台。当你在多个页面间传递参数时,通常有多种方法,例如通过 uni.navigateTo、路由参数、本地存储等方式。下面是一些方法的说明和示例代码。

1. 通过 uni.navigateTo 传参

当你使用 uni.navigateTo 进入新页面时,你可以在新页面的 onLoad 生命周期中获取到传入的参数。

示例代码

页面 A (index.vue)

<template>
<button @click="goToPageB">跳转到页面B</button>
</template>
<script>
export default {
methods: {
goToPageB() {
const data = { name: '张三', age: 20 }; // 这里是你要传递的数据
uni.navigateTo({
url: '/pages/pageB/pageB?data=' + JSON.stringify(data) // 通过URL携带数据
});
}
}
}
</script>

页面 B (pageB/index.vue)

<template>
<div>姓名:{{ name }},年龄:{{ age }}</div>
</template>
<script>
export default {
data() {
return {
name: '',
age: ''
};
},
onLoad: function (options) {
const data = JSON.parse(options.data); // 从URL中获取数据
this.name = data.name;
this.age = data.age;
}
}
</script>

2. 通过路由参数传参

如果你使用的是 Vue Router,你可以在路由配置中定义参数,然后在页面中通过 $route.params 获取。

示例代码 (需要先安装和配置 Vue Router)

路由配置 (router.js)

const routes = [
{ path: '/pageB/:data', component: PageB } // :data 是动态段,可以传递任何数据
];

页面 B (PageB.vue)

<template>
<div>姓名:{{ name }},年龄:{{ age }}</div>
</template>
<script>
export default {
data() {
return {
name: '',
age: ''
};
},
created() {
const data = this.$route.params.data; // 从路由参数中获取数据,注意是字符串,需要转换回对象或按需处理。这里只是一个简单示例。
const parsedData = JSON.parse(data); // 转换回对象(假设你的数据是JSON格式)
this.name = parsedData.name; // 使用转换后的数据,根据实际情况可能需要进一步处理或映射。
this.age = parsedData.age;
}
}
</script>

3. 通过本地存储(LocalStorage、SessionStorage等)传递数据。

这是一种不太推荐的方法,因为它并不是为了跨页面通信设计的。但它可以在某些场景下作为临时存储手段。例如:在 onLoad 中获取数据,在 onUnload 中保存数据。或者在用户关闭 app 后记住他们的状态等。使用时要注意数据的生命周期和安全性。

相关文章
|
4月前
|
安全 Java 应用服务中间件
【Azure 应用服务】App Service 默认页面暴露Tomcat版本信息,存在安全风险
【Azure 应用服务】App Service 默认页面暴露Tomcat版本信息,存在安全风险
|
27天前
|
缓存 数据处理 UED
App加载页面的等待体验设计技巧
App加载页作为整个用户体验的一部分,直接影响用户对于产品服务的忠诚度和满意度。
48 13
|
2月前
|
JSON API 网络安全
App数据的爬取
App数据的爬取
42 3
|
2月前
|
前端开发 UED 开发者
uni-app:去除导航栏&跨域的问题&blobe查看图片&v-deep&页面操作 (五)
本文介绍了几个前端开发技巧:1) 如何通过设置 `navigationStyle` 为 `custom` 去除顶部导航;2) 解决跨域问题的方法,包括使用 `dotenv` 加载全局变量和配置 `devServer` 的代理;3) 使用 Blob 和 FileReader 查看图片;4) 利用 `v-deep` 深度作用选择器修改样式;5) 修改页面左上角返回按钮的行为。
|
4月前
|
应用服务中间件 Linux 网络安全
【Azure 应用服务】App Service for Linux 环境中为Tomcat页面修改默认的Azure 404页面
【Azure 应用服务】App Service for Linux 环境中为Tomcat页面修改默认的Azure 404页面
|
4月前
|
安全 JavaScript 应用服务中间件
【Azure Function App】如何修改Azure函数应用的默认页面呢?
【Azure Function App】如何修改Azure函数应用的默认页面呢?
|
4月前
|
JavaScript 前端开发
【Azure Developer】在App Service上放置一个JS页面并引用msal.min.js成功获取AAD用户名示例
【Azure Developer】在App Service上放置一个JS页面并引用msal.min.js成功获取AAD用户名示例
|
4月前
|
JavaScript Linux 应用服务中间件
【Azure 应用服务】FTP 部署 Vue 生成的静态文件至 Linux App Service 后,访问App Service URL依旧显示Azure默认页面问题
【Azure 应用服务】FTP 部署 Vue 生成的静态文件至 Linux App Service 后,访问App Service URL依旧显示Azure默认页面问题
|
4月前
|
存储 SQL JSON
【Azure Logic App】微软云逻辑应用连接到数据库,执行存储过程并转换执行结果为JSON数据
【Azure Logic App】微软云逻辑应用连接到数据库,执行存储过程并转换执行结果为JSON数据
【Azure Logic App】微软云逻辑应用连接到数据库,执行存储过程并转换执行结果为JSON数据
|
4月前
|
缓存
【Azure Function】Function App代码中使用Managed Identity认证获取Blob数据时遇见400报错
【Azure Function】Function App代码中使用Managed Identity认证获取Blob数据时遇见400报错
【Azure Function】Function App代码中使用Managed Identity认证获取Blob数据时遇见400报错

热门文章

最新文章

下一篇
DataWorks