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

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.kler.cn/a/394589.html

相关文章:

  • 网络安全【C10-2024.10.1】-sql注入基础
  • 交换机关于环路、接口绑定、链路聚合的相关知识
  • 17爬虫:关于DrissionPage相关内容的学习01
  • 计算机的错误计算(二百)
  • 代码随想录算法训练营第五十二天|KM101.孤岛的总面积|KM102.沉没孤岛|KM103.水流问题|KM104.建造最大岛屿
  • 分数阶傅里叶变换代码 MATLAB实现
  • 【go从零单排】Ticker
  • Python自动化操作JSON文件详解
  • 在Ubuntu 24.04 LTS上安装飞桨PaddleX
  • uniapp隐藏自带的tabBar
  • 【刷题19】队列+bfs专题
  • 生成自签名证书并配置 HTTPS 使用自签名证书
  • uni-app快速入门(四)--maninfest.json及pages.json配置
  • CSS新特性
  • Ai编程从零开始全栈开发一个后台管理系统之用户登录、权限控制、用户管理-前端部分(十二)
  • nacos配置中心入门
  • 【达梦数据库】参数优化脚本主要改什么
  • spark.default.parallelism 在什么时候起作用,与spark.sql.shuffle.partitions有什么异同点?
  • LaTeX中浮动体(图片、表格)的位置及上下间距设置
  • 使用命令强制给ESXI上的硬盘分区
  • Grafana Username password invalid
  • JavaScript的展开运算符在React中的应用
  • 游戏引擎学习第11天
  • 软件测试计划和测试用例详解
  • 鸿蒙学习生态应用开发能力全景图-鸿蒙生态伙伴 SDK 市场(4)
  • 家政服务平台管理系统(源码+文档+部署+讲解)