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

uniapp在app模式下组件传值

在 UniApp 编译成 App 后,传递参数可以通过多种方式实现,常见的方式有以下几种:

1. 通过 URL 参数传递(适用于 WebView)

  • 如果你的 App 页面通过 WebView 渲染,可以像在 Web 端一样通过 URL 传递参数。例如:
    uni.navigateTo({url: '/pages/targetPage/targetPage?param=value'
    });
    
  • 目标页面可以通过 onLoad 获取参数:
    onLoad(options) {console.log(options.param); // 获取 URL 中的 param 参数
    }
    

2. 通过 Vuex 全局状态管理

  • 在 Vue 3 中,可以利用 Vuex 进行全局状态管理,传递全局参数。例如:
    // 在组件中设置 Vuex 状态
    this.$store.commit('setUser', userInfo);
    
    在 Vuex 中定义 mutation:
    const store = createStore({state: {user: null,},mutations: {setUser(state, userInfo) {state.user = userInfo;},},
    });
    
    其他页面可以通过 this.$store.state.user 获取到全局状态。

3. 通过全局变量(例如 globalData)传递参数

  • UniApp 提供了 getApp() 来访问全局的数据。可以在全局 App 实例中设置数据,然后在页面中获取。
    // 在 App.vue 中设置全局数据
    App({globalData: {userInfo: null}
    });
    
    在页面中获取全局数据:
    const app = getApp();
    console.log(app.globalData.userInfo);
    

4. 通过 Storage 本地存储传递参数

  • 使用 uni.setStorageSyncuni.getStorageSync 存储参数,能够在不同页面间传递数据。
    // 设置存储
    uni.setStorageSync('userInfo', userInfo);
    
    在目标页面获取数据:
    const userInfo = uni.getStorageSync('userInfo');
    console.log(userInfo);
    

5. 通过事件总线传递参数

  • 如果你希望在不同页面或组件之间传递数据,而不依赖于存储或 Vuex,可以使用事件总线进行通信。
  • 创建一个全局的事件总线:
    // eventBus.js
    export const eventBus = new Vue();
    
  • 在一个组件中发出事件:
    eventBus.$emit('userUpdated', userInfo);
    
  • 在目标页面或组件中监听事件:
    eventBus.$on('userUpdated', (data) => {console.log(data); // 获取传递的数据
    });
    

6. 通过参数直接传递(适用于组件)

  • 如果你是在不同的组件之间传递数据,可以直接通过 props 传递参数:
    // 父组件
    <child-component :userInfo="userInfo"></child-component>
    
    // 子组件
    props: {userInfo: Object
    }
    

7. 通过原生 API 传递参数

  • 对于原生功能,可以通过 UniApp 提供的原生 API 进行通信。例如,通过 uni.setNativeStorageuni.getNativeStorage 进行原生数据存储和获取。

总结:在 UniApp 中,传参方式的选择依赖于你使用的场景和需求。如果是简单的页面跳转,可以通过 URL 参数或 Vuex 全局状态管理;如果需要在页面间长期存储数据,推荐使用 uni.setStorageglobalData 进行传递。

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

相关文章:

  • Docker解决暴露2375端口引发的安全漏洞
  • HTML5+CSS前端开发【保姆级教学】+新闻文章初体验
  • 『VUE』26. props实现子组件传递数据给父组件(详细图文注释)
  • RHCE-DNS域名解析服务器
  • 移民统计年鉴(1996-2021年)
  • MFC1(note)
  • 1.1 关于游戏编程
  • 光流法与直接法在SLAM中的应用
  • C++模板特化实战:在使用开源库boost::geometry::index::rtree时,用特化来让其支持自己的数据类型
  • 让空间计算触手可及,VR手套何以点石成金?
  • 穿越数据迷宫:C++哈希表的奇幻旅程
  • SMT32 智能环境监测系统 嵌入式初学者课堂小组作业
  • 20241114给荣品PRO-RK3566开发板刷Rockchip原厂的Android13下适配RJ45以太网卡
  • JVM这个工具的使用方法
  • 创建型设计模式与面向接口编程
  • 算法每日双题精讲——滑动窗口(长度最小的子数组,无重复字符的最长子串)
  • 1.7 JS性能优化
  • STL - vector的使用和模拟实现
  • 《鸿蒙生态:开发者的机遇与挑战》
  • 【C++融会贯通】二叉树进阶
  • 使用python-Spark使用的场景案例具体代码分析
  • 如何查看本地的个人SSH密钥
  • 本人认为 写程序的三大基本原则
  • A030-基于Spring boot的公司资产网站设计与实现
  • React Hooks 深度解析与实战
  • #渗透测试#SRC漏洞挖掘#蓝队基础之网络七层杀伤链04 终章
  • 计算机毕业设计Python+大模型农产品推荐系统 农产品爬虫 农产品商城 农产品大数据 农产品数据分析可视化 PySpark Hadoop
  • 爬虫补环境案例---问财网(rpc,jsdom,代理,selenium)
  • SpringBoot有几种获取Request对象的方法
  • 在 Windows 11 中使用 MuMu 模拟器 12 国际版配置代理