官网   
npm install vue-router --savenpm install vue-loader --savenpm run devnpm run serveyarn run serve  
demo 1 2 3 4 5 6 7 8 import  Vue  from  'vue' import  router from  './router' new  Vue ({render : h  =>h (App )'#app' )
1 2 3 4 <router-link  to ='/foo' > go to foo</router-link > <router-link  to ='/bar' > go to bar</router-link > <router-link  :to ="{'name':'About'}" > about</router-link > <router-view > </router-view > 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 import  Vue  from  'vue' import  Router  from  'vue-router' import  Home  from  './views/Home.vue' import  Login  from  './views/Login.vue' import  Index  from  './views/Index.vue' Vue .use (Router )export  default  new  Router ({'history' ,base : process.env .BASE_URL ,'/' ,'home' ,Home '/index' ,'index' ,Index '/about' ,'about' ,() =>  import ('./views/About.vue' )'/login' ,'login' ,Login 
模板内容 1 2 3 4 5 6 7 8 9 10 11 12 13 14 <script > export  default ({    computed : {         username (             return  this .$router .params .username          }     },     methods : {         goBack (             window .history .length  > 1  ? this .$router .go (-1 ) : this .$router .push ('/' )         }     } }) </script > 
嵌套路由 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 export  default  new  router ({'/' ,'index' ,Index ,title :'内部资料' ,keyword :'首页' ,description :'data' },children :[{'second' ,'second' ,title :'内部资料1' ,keyword :'首页1' ,description :'data1' }
动态路由 1 2 3 4 5 6 7 8 9 export  default  new  router ({'/about/:id' ,'about' ,About 
路由全路径检测 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 beforeEach ((to, from , next ) =>  {if  (to.matched .some (record  =>meta .requireLogin )){  if  (sessionStorage .getItem ('loginInfo' )) {  next ();else  {next ({path : '/login' else  {next ();
跨域设置 config>index.js>dev:{}
1 2 3 4 5 6 7 8 9 将target设置为我们需要访问的域名,然后在main.js 中设置全局属性:Vue .prototype HOST  = '/api' var  url = this .HOST  + '/movie/in_theaters' this .$http .get (url).then (res  =>this .movieList  = res.data .subjects ;res  =>console .info ('调用失败' );
路由懒加载 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 import  Vue  from  'vue' import  Router  from  'vue-router' Vue .use (Router )function  loadView (view ) {return  () =>  import ( `@/views/${view} .vue` )export  default  new  Router ({routes : [path : '/home' ,name : 'home' ,component : loadView ('Home' )path : '/about' ,name : 'about' ,component : loadView ('About' )
去掉#号 1 2 3 4 5 const  router = new  VueRouter ({mode : '' ,base : process.env .BASE_URL ,