vue - 路由精讲 - 代码抽离和复用router-view

1.将之前所写的main.js中的 路由代码 进行抽离

首先我们在src文件夹下建立一个routes.js文件,然后把   import 引入Home 组件开始,一直到三级路由中PersonName组件得代码和  const routers = [ ] 代码抽离到  routes.js 中。只要在抽离后的routes.js的代码  const routers = [ ]  前面加个export 表示公开,,就OJBK 了。同时,为了代码简洁,把  抛砖引玉 且  目前没有什么用的  全局守卫代码  删除。

 

main.js代码

 1 import Vue from 'vue'
 2 import VueRouter from 'vue-router'
 3 import App from './App.vue'
 4 import Home from './components/Home.vue'
 5 import Menu from './components/Menu.vue'
 6 import Admin from './components/Admin.vue'
 7 import About from './components/about/About.vue'
 8 import Login from './components/Login.vue'
 9 import Register from './components/Register.vue'
10 
11 //二级路由
12 import Contact from './components/about/Contact.vue'
13 import Delivery from './components/about/Delivery.vue'
14 import History from './components/about/History.vue'
15 import OrderingGuide from './components/about/OrderingGuide.vue'
16 
17 //三级路由
18 import Phone from './components/about/contact/Phone.vue'
19 import PersonName from './components/about/contact/PersonName.vue'
20 
21 
22 
23 
24 Vue.use(VueRouter)
25 
26 const routes = [
27     {path:'/',      name:'homeLink',   component:Home},
28     {path:'/menu',  name:'menuLink',   component:Menu},
29     {path:'/admin', name:'adminLink',  component:Admin},
30     {path:'/about', name:'aboutLink', redirect:'/about/contact', component:About, children:[
31         {path:'/about/contact', name:'contactLink', redirect:'/personName', component:Contact, children:[
32             {path:'/phone', name:"phoneNumber", component:Phone},
33             {path:'/personName', name:"personName", component:PersonName},
34         ]},
35         {path:'/history',name:'historyLink',component:History},
36         {path:'/delivery',name:'deliveryLink',component:Delivery},
37         {path:'/orderingGuide',name:'orderingGuideLink',component:OrderingGuide},
38     ]},
39     {path:'/login', name:'loginLink',  component:Login},
40     {path:'/register', name:'registerLink', component:Register},
41     // {path:'*',redirect:'/'},
42 ]
43 
44 const router = new VueRouter({
45     routes,
46     mode:'history'
47 })
48 
49 
50 // //全局守卫
51 // router.beforeEach((to,from,next)=>{
52 //     // alert("还没有登录,请先登陆");
53 //     // next();
54 //     // console.log(to);
55 
56 //     //判断store.gettes.isLogin === false
57 //     if(to.path == '/login' || to.path == '/register'){
58 //         next();
59 //     }else{
60 //         alert("还没有登录,请先登陆");
61 //         next('/login');
62 //     }
63 // })
64 
65 new Vue({
66   el: '#app',
67   router,
68   render: h => h(App)
69 })

 

routes.js 代码

 1 import Home from './components/Home.vue'
 2 import Menu from './components/Menu.vue'
 3 import Admin from './components/Admin.vue'
 4 import About from './components/about/About.vue'
 5 import Login from './components/Login.vue'
 6 import Register from './components/Register.vue'
 7 
 8 //二级路由
 9 import Contact from './components/about/Contact.vue'
10 import Delivery from './components/about/Delivery.vue'
11 import History from './components/about/History.vue'
12 import OrderingGuide from './components/about/OrderingGuide.vue'
13 
14 //三级路由
15 import Phone from './components/about/contact/Phone.vue'
16 import PersonName from './components/about/contact/PersonName.vue'
17 
18 
19 export const routes = [
20     {path:'/',      name:'homeLink',   component:Home},
21     {path:'/menu',  name:'menuLink',   component:Menu},
22     {path:'/admin', name:'adminLink',  component:Admin},
23     {path:'/about', name:'aboutLink', redirect:'/about/contact', component:About, children:[
24         {path:'/about/contact', name:'contactLink', redirect:'/personName', component:Contact, children:[
25             {path:'/phone', name:"phoneNumber", component:Phone},
26             {path:'/personName', name:"personName", component:PersonName},
27         ]},
28         {path:'/history',name:'historyLink',component:History},
29         {path:'/delivery',name:'deliveryLink',component:Delivery},
30         {path:'/orderingGuide',name:'orderingGuideLink',component:OrderingGuide},
31     ]},
32     {path:'/login', name:'loginLink',  component:Login},
33     {path:'/register', name:'registerLink', component:Register},
34     // {path:'*',redirect:'/'},
35 ]

 

 

抽离后的main.js代码

 1 import Vue from 'vue'
 2 import VueRouter from 'vue-router'
 3 import App from './App.vue'
 4 import {routes} from './routes.js'
 5 
 6 Vue.use(VueRouter)
 7 
 8 const router = new VueRouter({
 9     routes,
10     mode:'history'
11 })
12 
13 new Vue({
14   el: '#app',
15   router,
16   render: h => h(App)
17 })

 

 

 

2.复用router-view

应用场景:比如我们想在  主页  中展示  历史订单   快递信息  点餐文档 这三个部分的信息,可以使用  router-view 复用。

具体步骤:在app.vue添加展示的内容,然后在routes.js 中   

 把原本的   componet:Home 展示的单个组件变成componets复数,然后一个对象{},在里面添加组件。

一进来就添加  default:Home,  组件, 然后再是添加需要展示的组件模块。具体代码如下

 

 

app.vue代码

 1 <template>
 2   <div id="app">
 3     <div class="container">
 4       <app-header></app-header>
 5     </div>
 6 
 7     <div class="container">
 8         <router-view></router-view>
 9     </div>
10 
11     <div class="container">
12       <div class="row">                                    //代表行
13         <div class="col-sm-12 col-md-4">                   //小屏模式下展示12列,中屏展示四列。
14           <router-view name="orderingGuide"></router-view>
15         </div>
16         <div class="col-sm-12 col-md-4">
17           <router-view name="delivery"></router-view>
18         </div>
19         <div class="col-sm-12 col-md-4">
20           <router-view name="history"></router-view>
21         </div>
22       </div>
23     </div>
24   </div>
25 </template>
26 
27 <script>
28 import Header from './components/Header.vue';
29 export default {
30   components:{
31     //"app-header":Header
32     appHeader:Header
33   }
34 }
35 </script>
36 
37 <style>
38 
39 </style>

 

 

 routes.js添加的代码

1 export const routes = [
2     {path:'/',      name:'homeLink',   components:{          
3         default:Home,
4         'orderingGuide':OrderingGuide,
5         'delivery':Delivery,
6         'history':History
7     }},
8     {path:'/menu',  name:'menuLink',   component:Menu},
9     {path:'/admin', name:'adminLink',  component:Admin},

 

posted @ 2018-08-05 16:56  甘劭  阅读(2088)  评论(0编辑  收藏  举报