在脚手架里使用路由(推荐)
1. 安装vue-router到项目中
npm i vue-router@3.4.8
2. 修改目录结构
3. 主要代码
import Vue from 'vue'
//导入路由模块
import Router from 'vue-router'
//将路由使用的组件导入
import Home from "@/views/Home";
import Second from "@/views/Second";
//在脚手架中需要手动注册路由功能到Vue中
Vue.use(Router)
//创建路由实例对象
const router = new Router({
routes: [
{
path: '/',
component: Home
},
{
path:'/second',
component:Second
}
]
})
// 导出路由实例
export default router
src/main.js:
import Vue from 'vue'
import App from './App.vue'
//导入路由实例对象
import router from "@/router";
Vue.config.productionTip = false
new Vue(
{
//添加到主Vue对象里
router,
render: h => h(App),
}).$mount('#app')
二
RESTFul式传参
路由配置:
var myRouter = new VueRouter({
routes:[
//用/:参数名形式书写path
{path:"/r1/:name/:age",component:"template1"}
]
});
链接跳转传参:
<router-link to="/r1/lins/27"></router-link>
JS跳转传参:
this.$router.push("/r1/lins/27");
收参
组件模板(HTML部分)收参:
{{$route.params.name}}
{{$route.params.age}}
组件中JS部分收参:
this.$route.params.name;
this.$route.params.age;
query式传参
query式就是把参数直接以?querystring的形式直接拼接到地址栏上。这种传参方式在路由配置时不需要额外配置参数接收。
链接跳转传参:
<router-link to="/r2?name=lins&age=27"></router-link>
JS跳转传参:
this.$router.push("/r2?name=lins&age=27");
收参
组件模板(HTML部分)收参:
{{$route.query.name}}
{{$route.query.age}}
组件中JS部分收参:
this.$route.query.name;
this.$route.query.age;
$route对象和VueRouter对象
VueRouter对象是控制整个路由系统的对象,切换路由的操作都是依靠VueRouter对象进行的(router-link算是快捷方式),可以通过
$router
(JS中为this.$router
)来获取VueRouter对象。
r o u t e 对象是当前路由的信息对象,可以使用 ‘ route对象是当前路由的信息对象,可以使用` route对象是当前路由的信息对象,可以使用‘route.params获取当前路由的参数、使用
r o u t e . p a t h ‘ 可以拿到当前路由的路径。( J S 中为 ‘ t h i s . route.path`可以拿到当前路由的路径。(JS中为`this. route.path‘可以拿到当前路由的路径。(JS中为‘this.route`)
动态添加路由规则(了解)
有时,我们需要某些路由规则不是在页面刚加载时就生效,而是在满足某些条件时生效。
比如我们做的应用里,有些页面(路由视图)需要在用户登录后才能访问,用户在没有登录时,即使在地址栏中直接输入那些页面的URL,也是无法访问的。
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>基本路由</title>
<script src="vue.2.6.12.js"></script>
<script src="vue-router.3.4.8.js"></script>
</head>
<body>
<button onclick="test()">按钮</button>
<div id="app">
<router-link to="/">路由1</router-link>
<router-link to="/r2">路由2</router-link>
<router-view></router-view>
</div>
<script>
let myTemplate1 = {
template:`<div>AAA-这是路由1-AAA</div>`
};
let myTemplate2 = {
template:`<div>BBB-这是路由2-BBB</div>`
};
let myRouter = new VueRouter({
//写在这里的路由规则,在页面加载时就生效
routes:[
{path:"/",component:myTemplate1}
]
});
let main = new Vue({
el:"#app",
router:myRouter
});
function test(){
//动态添加路由规则,和routes数组写法相同
myRouter.addRoutes([
{path:"/r2",component:myTemplate2}
])
}
</script>
</body>
</html>