vue中路由管理(vue-router,page)使用总结

2024-09-08 02:32

本文主要是介绍vue中路由管理(vue-router,page)使用总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

现在的项目都以模块化的方式去开发,所以在这样的开发模式下,如何更好的去管理路由是开发中所需要考虑的重点,幸运的是当前的开发中已经有了成熟的中间件去管理,我们只需要用就可以了

下面是我在学习vue-router的时候在原来基础上修改出来的demo,也是为了有助于对vue-router的理解

首先理解下vue官网的一个示例demo

https://jsfiddle.net/yyx990803/xgrjzsup/

 

这里展示的是完成一个路由所必须的基础步骤,由于这里不是模块化的开发模式,下面就是一个简单的demo使用模块化开发

github:https://github.com/chrisvfritz/vue-2.0-simple-routing-example

这里首先提供一个叫page.js的三方包去管理路由,将大幅度简化原有代码的书写比例,链接如下:

page.js:https://github.com/visionmedia/page.js

使用page后的代码简化:https://github.com/chrisvfritz/vue-2.0-simple-routing-example/compare/master...pagejs

可以拉下来自己测试下,在原来的基础上我想去使用vue-router,这里因为个人原因代码无法上传github,所以只能列出来代码防止以后忘记,便于复习

首先是文件的目录树

首先是 main.js,这里绑定了路由的文件,挂载了路由组件显示的位置

import Vue from 'vue'
import VueRouter from 'vue-router'
import routerConfig from '../src/routes.js'
import appHome from './pages/appHome.vue'
Vue.use(VueRouter)
const router = new VueRouter({routes:routerConfig
}) 
const app = new Vue({router,render:h=>h(appHome)
}).$mount('#app');

apphome:这里是主路由页面,里面定义了两个路由和一个展示路由组件的位置

<template><div><p><router-link to="/home">Home</router-link><router-link to="/home/about">/home/About</router-link></p><router-view></router-view></div>  
</template>
<script>
export default {name:'appHome',
}
</script>

router.js:定义路由地址和组件的绑定关系,这里加载布局有层级关系(即通过路由一层层的去加载布局组件),也是布局组件加载到每一个组件的主要部分

import Home from './pages/Home.vue'
import About from './pages/About.vue'
import MainLayout from "../src/layouts/Main.vue";
import notFound from './pages/404.vue'
const routerConfig=[{path: '/home', component: MainLayout,//加载布局组件children:[{path:'',component:Home},{path:'about',component:About}]
},
{path:'/about',component:notFound
}
]
export default routerConfig

main.vue:主要页面布局

<template><div class="container"><ul><li><router-link to="/home">Home</router-link><router-link to="/about">About</router-link></li></ul><router-view></router-view></div>
</template><script>import VLink from '../components/VLink.vue'export default {name: 'main-view',components: {VLink}}
</script><style scoped>.container {max-width: 600px;margin: 0 auto;padding: 15px 30px;background: #f9f7f5;}
</style>

vlink.vue,这里很鸡肋,就是一个展示链接是否访问的

<template><av-bind:href="href"v-bind:class="{ active: isActive }"></a>
</template><script>export default {props: {href: {type:String,required: true }},computed: {isActive () {return this.href === window.location.pathname}}}
</script><style scoped>.active {color: cornflowerblue;}
</style>

home:页面文件,跟about页面类似展示内容

<template><div><p>Welcome home</p></div>
</template><script>
export default {name: 'Home',mounted(){console.log('is home')}};
</script>

大概的文件都放在上方了,使用vue-router路由的主要注意点就是如何去加载布局组件的问题,他的事项是将路由的链接和组件绑定在一起,所以可以通过配置子链接的方式去一层层的加载组件布局

这篇关于vue中路由管理(vue-router,page)使用总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1146859

相关文章

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

SpringBoot使用Apache Tika检测敏感信息

《SpringBoot使用ApacheTika检测敏感信息》ApacheTika是一个功能强大的内容分析工具,它能够从多种文件格式中提取文本、元数据以及其他结构化信息,下面我们来看看如何使用Ap... 目录Tika 主要特性1. 多格式支持2. 自动文件类型检测3. 文本和元数据提取4. 支持 OCR(光学

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

Linux使用dd命令来复制和转换数据的操作方法

《Linux使用dd命令来复制和转换数据的操作方法》Linux中的dd命令是一个功能强大的数据复制和转换实用程序,它以较低级别运行,通常用于创建可启动的USB驱动器、克隆磁盘和生成随机数据等任务,本文... 目录简介功能和能力语法常用选项示例用法基础用法创建可启动www.chinasem.cn的 USB 驱动

C#使用yield关键字实现提升迭代性能与效率

《C#使用yield关键字实现提升迭代性能与效率》yield关键字在C#中简化了数据迭代的方式,实现了按需生成数据,自动维护迭代状态,本文主要来聊聊如何使用yield关键字实现提升迭代性能与效率,感兴... 目录前言传统迭代和yield迭代方式对比yield延迟加载按需获取数据yield break显式示迭

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

java脚本使用不同版本jdk的说明介绍

《java脚本使用不同版本jdk的说明介绍》本文介绍了在Java中执行JavaScript脚本的几种方式,包括使用ScriptEngine、Nashorn和GraalVM,ScriptEngine适用... 目录Java脚本使用不同版本jdk的说明1.使用ScriptEngine执行javascript2.

c# checked和unchecked关键字的使用

《c#checked和unchecked关键字的使用》C#中的checked关键字用于启用整数运算的溢出检查,可以捕获并抛出System.OverflowException异常,而unchecked... 目录在 C# 中,checked 关键字用于启用整数运算的溢出检查。默认情况下,C# 的整数运算不会自

在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码

《在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码》在MyBatis的XML映射文件中,trim元素用于动态添加SQL语句的一部分,处理前缀、后缀及多余的逗号或连接符,示... 在MyBATis的XML映射文件中,<trim>元素用于动态地添加SQL语句的一部分,例如SET或W