当前位置: 首页 > news >正文

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 后记住他们的状态等。使用时要注意数据的生命周期和安全性。

http://www.lryc.cn/news/275673.html

相关文章:

  • 计算机网络实验(二):Wireshark网络协议分析
  • Spark内核解析-数据存储5(六)
  • ASP.NET Core高级之认证与授权(一)--JWT入门-颁发、验证令牌
  • 实例:NodeJS 操作 Kafka
  • AI实景无人直播创业项目:开启自动直播新时代,一部手机即可实现增长
  • YOLOv5改进 | 损失函数篇 | InnerIoU、InnerSIoU、InnerWIoU、FocusIoU等损失函数
  • 构建高效PythonWeb:GraphQL+Sanic
  • 【通义千问】大模型Qwen GitHub开源工程学习笔记(5)-- 模型的微调【全参数微调】【LoRA方法】【Q-LoRA方法】
  • PCL 大地坐标转空间直角坐标(C++详细过程版)
  • Linux之Shell编程
  • Unity组件开发--传送点
  • vue结合Cesium加载gltf模型
  • 逆置算法和数组循环移动算法
  • 【MATLAB】数豆子
  • QT C++中调用python脚本时,import第三方库失败问题解决
  • 【AI视野·今日Robot 机器人论文速览 第七十期】Thu, 4 Jan 2024
  • Flutter中的布局组件介绍及使用
  • 【面试高频算法解析】算法练习2 回溯(Backtracking)
  • 认识Git
  • @RequestParam,@RequestBody和@PathVariable 区别
  • vue3组件传参
  • React16源码: React中创建更新的方式及ReactDOM.render的源码实现
  • CentOS 7 系列默认的网卡接口名称
  • 多文件上传
  • 2024.1.7力扣每日一题——赎金信
  • C#中List<T>底层原理剖析
  • Leetcode 3003. Maximize the Number of Partitions After Operations
  • MySQL第一讲:MySQL知识体系详解(P6精通)
  • 逻辑回归简单案例分析--鸢尾花数据集
  • Python print 高阶玩法