Java老鸟前端小白uniapp+uview开发小程序第2天

声明一下:该系列文章不定时更新,更新也没有预定顺序,纯粹是自己开发笔记。

今天的内容有:

  • uniapp的页面路由、跳转、参数、Vuex等

1、uniapp页面

  • pages文件夹下新建vuenvue文件

  • pages.json配置页面属性

    复制代码
    "pages": [ //pages数组中第一项表示应用启动页,参考:https://uniapp.dcloud.io/collocation/pages
    	{
    		"path": "pages/index/index",
    		"style": {
    			"navigationBarTitleText": "首页"
    		}
    	},
    	{
    		"path" : "pages/home/home",
    		"style" : 
    		{
    			"navigationBarTitleText" : "新朋友"
    		}
    	}
    ],

以上步骤使用HbuilerX创建页面的时间会自动完成

2、页面跳转

2.1 uni.navigateTo

跳转到新页面,不会关闭当前页面

  • 不带参数:

    复制代码
    // 使用uni.navigateTo跳转到新页面
    uni.navigateTo({
    	url: '/pages/home/home' // 这里的URL是相对于pages.json中配置的路径
    });
  • 带有参数:

    • 带参数跳转

      复制代码
      function navigateToPageB() {
          const param = { id: 123, name: 'uniapp' };
          // 使用 encodeURIComponent 对参数进行编码
          const params = encodeURIComponent(JSON.stringify(param));
          uni.navigateTo({
              url: `/pages/pageB/pageB?params=${params}`
          });
      }
    • 接收参数

      复制代码
      export default {
          onLoad(options) {
              // 获取传递的参数
              if (options.params) {
                  // 使用 decodeURIComponent 解码并解析 JSON
                  const param = JSON.parse(decodeURIComponent(options.params));
                  console.log(param); // { id: 123, name: 'uniapp' }
              }
          }
      }
2.2 uni.redirectTo

跳转到新页面,会关闭当前页面

  • 不带参数:

    复制代码
    // 使用 uni.redirectTo 进行页面跳转 (会关闭当前页面)
    uni.redirectTo({
    	url: '/pages/home/home' // 这里的URL是相对于pages.json中配置的路径
    });
  • 带有参数:

    • 带参数跳转

      复制代码
      function redirectToPageB() {
          const param = { id: 123, name: 'uniapp' };
          // 使用 encodeURIComponent 对参数进行编码
          const params = encodeURIComponent(JSON.stringify(param));
          uni.redirectTo({
              url: `/pages/pageB/pageB?params=${params}`
          });
      }
    • 接收参数

      复制代码
      export default {
          onLoad(options) {
              if (options.params) {
                  const param = JSON.parse(decodeURIComponent(options.params));
                  console.log(param); 
              }
          }
      }

3、Vuex 全局状态

Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式和库。这里只记录它的用法:

3.1 用法1:页面传递参数
  • 设置 Vuex

    复制代码
    // store.js
    export const store = new Vuex.Store({
        state: {
            sharedData: null
        },
        mutations: {
            setSharedData(state, data) {
                state.sharedData = data;
            }
        }
    });
  • 页面设置数据

    复制代码
    import { mapMutations } from 'vuex';
    
    export default {
        methods: {
            ...mapMutations(['setSharedData']),
            navigateToPageB() {
                const data = { id: 789, name: 'vuex' };
                this.setSharedData(data); // 将数据存储在 Vuex 中
                uni.navigateTo({
                    url: '/pages/pageB/pageB'
                });
            }
        }
    }
  • 页面获取数据

    复制代码
    import { mapState } from 'vuex';
    
    export default {
        computed: {
            ...mapState(['sharedData'])
        },
        onLoad() {
            console.log(this.sharedData); // { id: 789, name: 'vuex' }
        }
    }

今天摸鱼到此,赶紧写代码去

相关推荐
_F_y9 分钟前
C++重点知识总结
java·jvm·c++
打工的小王10 分钟前
Spring Boot(三)Spring Boot整合SpringMVC
java·spring boot·后端
毕设源码-赖学姐12 分钟前
【开题答辩全过程】以 高校体育场馆管理系统为例,包含答辩的问题和答案
java·spring boot
我真会写代码13 分钟前
SSM(指南一)---Maven项目管理从入门到精通|高质量实操指南
java·spring·tomcat·maven·ssm
vx_Biye_Design14 分钟前
【关注可免费领取源码】房屋出租系统的设计与实现--毕设附源码40805
java·spring boot·spring·spring cloud·servlet·eclipse·课程设计
DN金猿19 分钟前
接口路径正确,请求接口却提示404
java·tomcat
Maynor9961 小时前
OpenClaw 玩家必备:用 AI 自动追踪社区最新动态
java·服务器·人工智能
堕2741 小时前
java数据结构当中的《排序》(一 )
java·数据结构·排序算法
亓才孓1 小时前
[Class的应用]获取类的信息
java·开发语言
开开心心就好1 小时前
AI人声伴奏分离工具,离线提取伴奏K歌用
java·linux·开发语言·网络·人工智能·电脑·blender