Uniapp 和 Vue 在路由方面有相似之处,因为 Uniapp 是基于 Vue 的。Uniapp 的路由系统是通过 Vue Router 实现的,因此两者有许多相同的概念和 API。

相同点:

  • 都支持基于 URL 的路由;
  • 都可以使用嵌套路由来管理多个页面之间的关系;
  • 都支持路由参数和查询参数的传递;
  • 都支持路由守卫(beforeEach、beforeEnter、beforeLeave)等功能。

不同点:

  • Vue Router 是针对 Web 应用开发的路由库,而 Uniapp 是为多个平台(包括小程序和 H5)开发的跨端框架。因此,Uniapp 的路由系统需要考虑不同平台的差异,例如小程序中没有浏览器的历史记录和前进后退功能;
  • 在使用 Uniapp 的时候,不需要手动配置路由,而是通过编写 pages.json 文件来配置页面路径和样式等信息。这一点与 Vue Router 的使用方式略有不同;
  • Uniapp 的路由跳转方法有些不同,例如 navigateTo、redirectTo、switchTab、reLaunch 等方法,这些方法都是针对不同场景的不同跳转方式。
  • 因此,Uniapp 和 Vue 在路由方面有相似之处,但是由于 Uniapp 的跨端特性和不同平台的差异,它们在具体实现和使用方式上也有些不同。

一. Uniapp路由的使用方式:
Uniapp 的路由使用方法分为两部分,一是在 pages.json 文件中配置页面路径和样式等信息,二是通过 uni.navigateTo、uni.redirectTo、uni.switchTab、uni.reLaunch 等方法进行页面跳转。下面详细介绍一下这两部分的内容。

配置页面路径和样式
在 Uniapp 中,我们可以在 pages.json 文件中配置页面路径和样式等信息。这个文件默认位于项目的根目录下,它是一个 JSON 格式的配置文件,用于描述所有页面的路径、样式、配置等信息。例如:

  1. {
  2. "pages": [
  3. {
  4. "path": "pages/index/index",
  5. "style": {
  6. "navigationBarTitleText": "首页"
  7. }
  8. },
  9. {
  10. "path": "pages/detail/detail",
  11. "style": {
  12. "navigationBarTitleText": "详情页"
  13. }
  14. }
  15. ],
  16. "tabBar": {
  17. "list": [
  18. {
  19. "pagePath": "pages/index/index",
  20. "text": "首页",
  21. "iconPath": "static/tab-bar/home.png",
  22. "selectedIconPath": "static/tab-bar/home-selected.png"
  23. },
  24. {
  25. "pagePath": "pages/mine/mine",
  26. "text": "我的",
  27. "iconPath": "static/tab-bar/mine.png",
  28. "selectedIconPath": "static/tab-bar/mine-selected.png"
  29. }
  30. ]
  31. }
  32. }

  

上面的代码片段中,我们定义了两个页面,分别是首页和详情页,它们的路径分别是 pages/index/index 和 pages/detail/detail,同时还定义了这两个页面的导航栏标题。另外,我们还定义了一个名为 tabBar 的对象,表示底部导航栏的样式和配置信息。这个对象中包含一个名为 list 的数组,数组中的每个对象表示一个底部导航栏项。

跳转页面
在 Uniapp 中,我们可以通过 uni.navigateTo、uni.redirectTo、uni.switchTab、uni.reLaunch 等方法进行页面跳转。这些方法都是基于页面路径进行跳转的,它们的区别在于跳转的方式和效果不同。例如:

  • uni.navigateTo:保留当前页面,跳转到应用内的某个页面。新打开的页面可以通过 uni.navigateBack 方法返回到原来的页面。
  • uni.redirectTo:关闭当前页面,跳转到应用内的某个页面。新打开的页面不可以通过 uni.navigateBack 方法返回到原来的页面。
  • uni.switchTab:关闭所有页面,跳转到应用内的某个页面。新打开的页面是底部导航栏中的一个页面。
  • uni.reLaunch:关闭所有页面,打开应用内的某个页面。

例如,以下代码示例演示如何通过 uni.navigateTo 方法跳转到详情页:

  1. // 在 index 页面中跳转到详情页
  2. uni.navigateTo({
  3. url: '/pages/detail/detail'
  4. })

  

上面的代码片段中,我们通过 uni.navigateTo 方法跳转到了详情页,其中 url 参数表示要跳转的页面路径。这个路径应该是 pages.json 文件中定义的页面路径,可以是相对路径或绝对路径。

另外,如果要在跳转时传递参数,可以在路径后面加上查询字符串,例如:

  1. // 在 index 页面中跳转到详情页,并传递参数
  2. uni.navigateTo({
  3. url: '/pages/detail/detail?id=123'
  4. })

  

在详情页中可以通过 this.$route.query.id 获取参数值。
除了以上方法之外,还可以使用 uni.navigateBack 方法返回上一个页面。例如:

  1. // 在详情页中返回上一个页面
  2. uni.navigateBack()

  

上面的代码片段中,我们调用了 uni.navigateBack 方法返回上一个页面。

二. vue中路由的使用方法

1. 安装Vue Router
在使用Vue.js的路由功能之前,需要先安装Vue Router。可以使用npm或者yarn安装:

  1. npm install vue-router
  2. # 或者
  3. yarn add vue-router

  

2. 创建路由
在Vue.js中,我们需要先创建一个路由实例,然后定义路由映射关系。路由实例可以通过Vue Router提供的Vue.use()方法进行创建:

  1. import Vue from 'vue';
  2. import VueRouter from 'vue-router';
  3. import Home from './views/Home.vue';
  4. import About from './views/About.vue';
  5.  
  6. Vue.use(VueRouter);
  7.  
  8. const router = new VueRouter({
  9. mode: 'history',
  10. routes: [
  11. {
  12. path: '/',
  13. name: 'home',
  14. component: Home
  15. },
  16. {
  17. path: '/about',
  18. name: 'about',
  19. component: About
  20. }
  21. ]
  22. });
  23.  
  24. export default router;

  

在上述代码中,我们首先引入了Vue.js和Vue Router模块,并使用Vue.use()方法注册Vue Router。接着,我们创建了一个路由实例,并定义了两个路由映射关系。其中,路由映射关系包括路由路径(path)、路由名称(name)和路由组件(component)。

3. 添加路由实例
在创建了路由实例后,我们需要将其添加到Vue.js的根实例中,以便在整个应用程序中使用路由功能。可以在main.js文件中进行添加:

  1. import Vue from 'vue';
  2. import App from './App.vue';
  3. import router from './router';
  4.  
  5. new Vue({
  6. router,
  7. render: h => h(App),
  8. }).$mount('#app');

  

在上述代码中,我们首先引入了Vue.js的根组件(App.vue)和路由实例(router),然后将路由实例作为根实例的一个选项进行添加。

4. 创建路由组件
在定义路由映射关系时,需要指定路由组件。路由组件是一个普通的Vue.js组件,用于渲染对应的路由页面。可以在components文件夹下创建路由组件,例如:

  1. <template>
  2. <div>
  3. <h1>About Page</h1>
  4. </div>
  5. </template>
  6.  
  7. <script>
  8. export default {
  9. name: 'About'
  10. }
  11. </script>

  

在上述代码中,我们创建了一个名为About的组件,用于渲染关于页面。

5. 使用路由
在上述步骤完成后,就可以在Vue.js应用程序中使用路由了。可以在Vue.js组件中使用$route和$router来访问当前路由信息和导航功能,例如:

  1. <template>
  2. <div>
  3. <h1>{{ $route.name
  4. }}</h1>
  5. <p>Welcome to {{ $route.name }} page</p>
  6. <router-link to="/">Home</router-link>
  7. <router-link to="/about">About</router-link>
  8.  
  9. </div>
  10. </template>
  11. <script>
  12. export default {
  13. name: 'App'
  14. }
  15. </script>

  在上述代码中,我们使用$route.name访问当前路由名称,并在页面中显示。同时,使用<router-link>标签实现页面之间的导航。to属性用于指定目标路由路径。 除了使用<router-link>标签进行导航,还可以使用$router.push()方法进行编程式导航。例如:

  1. this.$router.push('/about');

  

上述代码用于在当前页面中进行路由跳转,进入关于页面。

6. 使用路由守卫
Vue Router还提供了路由守卫功能,用于在导航过程中进行控制和过滤。可以使用beforeEach()方法实现全局路由守卫,例如:

  1. router.beforeEach((to, from, next) => {
  2. if (to.name === 'about' && !isAuthenticated) next({ name: 'home' })
  3. else next()
  4. })

  

在上述代码中,我们定义了一个全局路由守卫,用于在进入关于页面之前进行身份验证。如果当前用户没有登录,则自动跳转到主页。

除了全局路由守卫外,Vue Router还提供了其他几种路由守卫,例如beforeEnter()、beforeRouteEnter()和beforeRouteLeave()等,用于在特定路由进入或离开时进行控制和过滤。

总之,Uniapp 的路由使用方法与 Vue 的路由使用方法基本相似,都是通过配置文件和方法进行跳转,只不过在具体实现细节上有些不同。

详解uniapp和vue在路由方面的不同和联系的更多相关文章

  1. react router @4 和 vue路由 详解(五)react怎么通过路由传参

    完整版:https://www.cnblogs.com/yangyangxxb/p/10066650.html 7.react怎么通过路由传参? a.通配符传参(刷新页面数据不丢失) //在定义路由的 ...

  2. react router @4 和 vue路由 详解(三)react如何在路由里面定义一个子路由

    完整版:https://www.cnblogs.com/yangyangxxb/p/10066650.html 5.react如何在路由里面定义一个子路由?   a.引入在需要子路由的页面引入Rout ...

  3. 详解如何在vue项目中引入饿了么elementUI组件

    在开发的过程之中,我们也经常会使用到很多组件库:vue 常用ui组件库:https://blog.csdn.net/qq_36538012/article/details/82146649 今天具体说 ...

  4. vue.js基础知识篇(6):组件详解

    第11章:组件详解 组件是Vue.js最推崇也最强大的功能之一,核心目标是可重用性. 我们把组件代码按照template.style.script的拆分方式,放置到对应的.vue文件中. 1.注册 V ...

  5. Vue不兼容IE8原因以及Object.defineProperty详解

    Vue不兼容IE8原因以及Object.defineProperty详解 原因概述: Vue.js使用了IE8不能模拟的ECMAScript5特性. Vue.js支持所有兼容ES5的浏览器. Vue将 ...

  6. Vue组件通信方式全面详解

    vue组件通信方式全面详解 众所周知,Vue主要思想就是组件化开发.因为,在实际的项目开发中,肯定会以组件的开发模式进行.形如页面和页面之间需要通信一样,Vue 组件和组件之间肯定也需要互通有无.共享 ...

  7. HDFS详解

    HDFS详解大纲 Hadoop HDFS 分布式文件系统DFS简介 HDFS的系统组成介绍 HDFS的组成部分详解 副本存放策略及路由规则 命令行接口 Java接口 客户端与HDFS的数据流讲解 目标 ...

  8. Sentry-CLI 使用详解(2021 Sentry v21.8.x)

    内容源于:https://docs.sentry.io/platforms/javascript/guides/vue/ 系列 1 分钟快速使用 Docker 上手最新版 Sentry-CLI - 创 ...

  9. Sentry 监控 - 私有 Docker Compose 部署与故障排除详解

    内容整理自官方开发文档 系列 1 分钟快速使用 Docker 上手最新版 Sentry-CLI - 创建版本 快速使用 Docker 上手 Sentry-CLI - 30 秒上手 Source Map ...

  10. Vue 路由详解

    Vue 路由详解 对于前端来说,其实浏览器配合超级连接就很好的实现了路由功能.但是对于单页面应用来说,浏览器和超级连接的跳转方式已经不能适用,所以各大框架纷纷给出了单页面应用的解决路由跳转的方案. V ...

随机推荐

  1. 关于webdriver和谷歌浏览器的那些事

    早上看了一个视频,讲述爬虫的,首先一开始就写了一行这样代码(如下): from selenium import webdriver # 创建浏览器对象 ,这会在电脑中打开浏览器窗口browser = ...

  2. python学习笔记-简介

    python简介 python是一种简单易学,功能强大的编程语言,他有高效的高层数据结构,简单而有效的实现面向对象编程.python是一种解释性语言,在多数平台的多个领域都是理想的脚本语言,特别适用于 ...

  3. css 背景渐变

    1.渐变从左到右 background: linear-gradient(to right,#000,#fff); 2.渐变从上到下 background: linear-gradient(tobot ...

  4. NIO基本介绍

    同步和异步,同步指的是应用程序会直接参与IO读写操作,用阻塞或者长轮询的方式来获取数据.异步指的是IO交给操作系统,完成IO读写后通知程序,程序直接拿走数据. BIO:同步阻塞式IO,服务器实现模式为 ...

  5. Callable、Future、FutureTash详解

    Callable.Future.FutureTash详解 Callable与Future是在JAVA的后续版本中引入进来的,Callable类似于Runnable接口,实现Callable接 口的类与 ...

  6. 数据库自动备份,crontab定时任务

    查看crontab运行状态service crond status 查看当前用户的crontab,输入 crontab -l: 编辑crontab,输入 crontab -e: 删除crontab,输 ...

  7. Windows10常用快捷键总结

    --Windows10常用快捷键总结 1. Window键: 打开或关闭|开始菜单 2. Win + A 打开操作中心 3. Win + D 显示桌面 4. Win + E 打开计算机文件管理器 5. ...

  8. __declspec(dllimport) 和 __declspec(dllexport)的使用详解、以及 XX_API 的含义

    1. C++代码里调用别人的库.或者写库给别人用.大概有如下的方法(只讨论windows系统的情况): ---- a) 提供头文件 h . 静态库 lib  -- > 静态链接 ---- b) ...

  9. 【vue】数据代理

    Object.defineProperty()方法 我们先来看几段代码 常用添加属性的方法,以添加age举例 ,点击查看代码 let person = { name: '张三', sex: '男', ...

  10. jxg项目Day2-git

    申请了我自己的gitee账号,建了我的仓库,在idea中点这个,然后就算漫长的自动下载的过程.. 对分支和冲突的理解:每个人都有自己的develop分支,可以commit到本地的分支,可以push到远 ...