vue-router的两种模式(vue-route路由管理的安装与配置方法)
vue-router的两种模式
vue-route路由管理的安装与配置方法介绍Vue Router
是 Vue.js
官方的路由管理器。它和 Vue.js
的核心深度集成,让构建单页面应用变得易如反掌。包含的功能有:
- 嵌套的路由/视图表
- 模块化的、基于组件的路由配置
- 路由参数、查询、通配符
- 基于 Vue.js 过渡系统的视图过渡效果
- 细粒度的导航控制
- 带有自动激活的 CSS class 的链接
- HTML5 历史模式或 hash 模式,在 IE9 中自动降级
- 自定义的滚动条行为
安装命令
npm install vue-router --save
如果在一个模块化工程中使用它,必须要通过 Vue.use()
明确地安装路由功能:
import Vue from 'vue' import VueRouter from 'vue-router' Vue.use(VueRouter)
之前我们使用脚手架vue-cli
创建项目时,实际已经配置好了router
,创建完项目后,在项目根目录下会有一个router
文件夹,router
下有一个index.js
文件,内容如下:
import Vue from "vue"; import VueRouter from "vue-router"; import Home from "../views/Home.vue"; // 1. 当我们使用其他插件的时候,就必须使用Vue.use安装插件 Vue.use(VueRouter); // 2. 定义路由,每个路由应该映射一个组件 const routes = [ { path: "/", name: "Home", component: Home, }, { path: "/about", name: "About", component: About }, ]; // 3. 创建router实例 const router = new VueRouter({ // 配置路由和组件之间的应用关系 routes, // (缩写) 相当于 routes: routes }); // 4. 导出router对象,然后在main.js中引用 export default router;
这个文件是专门配置路由的,最后将router
对象导出后,我们在项目的main.js
中引用即可
import Vue from "vue"; import App from "./App.vue"; import router from "./router"; Vue.config.productionTip = false; new Vue({ router, // 在vue实例中添加router对象,就可以使用路由了 render: (h) => h(App), }).$mount("#app");
我们的2个组件代码About
和Home
代码如下:
// About.vue <template> <li class="about"> <h1>About</h1> </li> </template> <script> export default { name: "About" } </script> <style scoped> </style> // Home.vue <template> <li class="home"> <h1>Home</h1> </li> </template> <script> export default { name: "Home", }; </script> <style scoped> </style>
最后我们在App.vue
中,写入如下代码:
template> <li id="app"> <router-link to="/">首页</router-link> <router-link to="/about">关于</router-link> <router-view></router-view> </li> </template> <style lang="scss"> </style>
使用<router-link>
来加载链接,然后使用to
表示跳转的链接。最终会把<router-link>
渲染成<a>
标签。
<router-view>
是路由的出口,也就是相应url
下的代码会被渲染到这个地方来。
但是当我们启动程序,访问页面的时候,url
地址上会出现#
这是因为vue-router
默认 hash
模式 —— 使用 URL
的 hash
来模拟一个完整的 URL
,于是当 URL
改变时,页面不会重新加载。
如果不想要很丑的 hash
,我们可以用路由的 history
模式,这种模式充分利用 history.pushState API
来完成 URL
跳转而无须重新加载页面。
const router = new VueRouter({ mode: 'history', routes: [...] })
我们只需在router
文件夹下的index.js
中添加mode
为history
即可,之后重新访问,http://localhost:8080/
就不会有#
号了
注意:history
模式还需要后台配置支持。因为我们的应用是个单页客户端应用,如果后台没有正确的配置,当用户在浏览器直接访问其他url
地址就会返回 404,这就不好看了。
所以呢,你要在服务端增加一个覆盖所有情况的候选资源:如果 URL
匹配不到任何静态资源,则应该返回同一个 index.html
页面,这个页面就是你 app
依赖的页面。
到此这篇关于vue-route路由管理的安装与配置 的文章就介绍到这了,更多相关vue route安装与配置 内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
- vue引入axios(vue封装axios的几种方法)
- vue项目打包上线的方法(vue项目打包以及优化的实现步骤)
- dockernginx服务器教程(Docker镜像+nginx 部署 vue 项目的方法)
- vue滚动条下拉翻页(Vue中利用better-scroll组件实现横向滚动功能)
- vue移动端返回在指定位置(vue移动端判断手指在屏幕滑动方向)
- vue接口请求类封装(Vue接口封装的完整步骤记录)
- vue移动端图片放大效果实现(vue实现图片切换效果)
- vue创建dom节点(Vue批量更新dom的实现步骤)
- electronvue最新版本(Vue3和Electron实现桌面端应用详解)
- vue调用组件内部的方法(Vue如何实现组件间通信)
- vue点击导航进行内容切换(vue实现顶部左右滑动导航)
- 使用vue-cli构建electron项目(MAC+PyCharm+Flask+Vue.js搭建系统)
- 使用vue独立开发组件(vue单文件组件的实现)
- vue 表格数据增加修改(vue element实现表格增加删除修改数据)
- vue跨域代理怎么写(解决vue $http的get和post请求跨域问题)
- vue如何加速(vue函数防抖与节流的正确使用方法)
- 毛戈平全国第一柜花落银泰 高端国货迎来 高光 时刻(毛戈平全国第一柜花落银泰)
- 14岁丧父 20岁丧母,从苦难走向辉煌的银泰创始人沈国军(14岁丧父20岁丧母从苦难走向辉煌的银泰创始人沈国军)
- 银泰集团董事长沈国军获评 北京影响力 十大企业家(银泰集团董事长沈国军获评)
- 15帅气男士发型,清爽时尚很有型,喜欢就试试(清爽时尚很有型)
- 哪几个历史人物被影协主席李雪健演的活灵活现(哪几个历史人物被影协主席李雪健演的活灵活现)
- 王伦狭隘,晁盖霸道,宋江奸诈骨头软,只有鲁智深才适合当寨主(王伦狭隘晁盖霸道)
热门推荐
- 为什么asp.net网站第一次加载慢
- dedecms标签怎么调用(dedecms网站栏目增加缩略图的方法)
- 如何让Select下拉框具有输入功能
- docker配置https访问方式(docker 中配置 eureka的方法)
- rename重命名mysql表(MySQL 重命名表的操作方法及注意事项)
- redis在php怎么使用(Windows服务器中PHP如何安装redis扩展)
- phpstudy数据库搭建教程交流(phpStudy V8如何修改数据库root密码)
- 常见的web服务器有哪些(web服务器是什么?web服务器怎么设置)
- secure file(解决出现secure_file_priv null的问题)
- 香港云服务器怎么那么火(如何选择便宜稳定的香港云服务器?)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9