Vue.js之路由

Vue.js之路由

 

  以前的跳转都是使用a标签,a标签里有一个属性叫href,给他一个对应的网络地址或者一个路径的话,它就会帮助跳转到对应的页面。

  Vue.js的路由,其实跟我们的a标签实现的功能是一样的,我们也是实现一个对应的跳转,只不过路由的性能更优化,a标签不管点击多少次,都会发生对应的网络请求,页面会不停地进行页面刷新,但是路由不一样,只要使用路由机制的话,你只要点击之后,他不会出现我们的请求以及页面刷新,直接就转换到你要去的地址,这是我们使用路由的好处。

  要使用路由,需要先安装路由模块,在IDE的Terminal中输入这句话: npm install vue-router --save-dev 来安装。
  安装路由模块以后就可以在项目里使用路由了。


  使用路由首先要在main.js当中进行设置,通过 import VueRouter from 'vue-router' 将我们的路由模块先引进来,然后在下面通过 Vue.use(VueRouter) 使用一下引用进来的模块。
  使用路由以后就可以在下面进行配置路由了:

复制代码
1 const router = new  VueRouter({
2   routes:[
3     {path:'/',component:Home},
4     {path:'/helloworld',component:HelloWorld}
5   ],
6   mode:"history"
7 })
复制代码

  path是要路由的地址,component是抓取到地址后要跳转到的组件。这里要跳转到的组件也要在main.js中引入. 

 例如: import HelloWorld from './components/HelloWorld' 和 import Home from './components/Home' 

 

一个小demo

 

  main.js文件:

复制代码
 1 import Vue from 'vue'
 2 import VueRouter from 'vue-router'
 3 import App from './App'
 4 import HelloWorld from './components/HelloWorld'
 5 import Home from './components/Home'
 6 
 7 Vue.config.productionTip = false
 8 Vue.use(VueRouter)
 9 
10 //配置路由
11 const router = new  VueRouter({
12   routes:[
13     {path:'/',component:Home},
14     {path:'/helloworld',component:HelloWorld},
15   ],
16   mode:"history"
17 })
18 
19 new Vue({
20   router,
21   el: '#app',
22   components: { App },
23   template: '<App/>'
24 })
复制代码

  要在路由中加 mode:”history“ ,否则项目地址会多出 localhost:8080/#/ ,会影响我们项目的功能。

  Home.vue文件:

复制代码
 1 <!--模板-->
 2 <template>
 3   <div id="home">
 4     <app-header @titleChanged="updateTitle($event)" :title="title"></app-header>
 5     <users :users="users"></users>
 6     <app-footer></app-footer>
 7   </div>
 8 </template>
 9 
10 <!--行为-->
11 <script>
12   //局部注册组件
13   import Users from './Users'
14   import Header from './Header'
15   import Footer from './Footer'
16 
17   export default {
18     name: 'home',
19     data(){
20       return {
21         users:[
22           {name:"Henry",Position:"Java工程师",show:false},
23           {name:"Lily",Position:"Java工程师",show:false},
24           {name:"Kang",Position:"Java工程师",show:false},
25           {name:"Henry",Position:"Java工程师",show:false},
26           {name:"Henry",Position:"Java工程师",show:false}
27         ],
28         title:"这是一个title!"
29       }
30     },
31     methods:{
32       updateTitle:function (title) {
33         this.title = title;
34       }
35     },
36     components:{
37       "users":Users,
38       "app-header":Header,
39       "app-footer":Footer
40     }
41 
42   }
43 </script>
44 
45 <!--样式-->
46 <style >
47 
48   h1{
49     color: pink;
50   }
51 </style>
复制代码

 

HelloWorld.vue文件:

复制代码
 1 <template>
 2   <div class="hello">
 3       hello,world!
 4   </div>
 5 </template>
 6 
 7 <script>
 8 export default {
 9   name: 'HelloWorld',
10   data () {
11     return {
12     }
13   }
14 }
15 </script>
16 
17 <!-- Add "scoped" attribute to limit CSS to this component only -->
18 <style scoped>
19 
20 </style>
复制代码

  Header.vue文件:

复制代码
 1 <template>
 2   <header @click="changeTitle">
 3     <h1>{{title}}</h1>
 4   </header>
 5 </template>
 6 
 7 <script>
 8   export default {
 9     name: 'app-header',
10     data () {
11       return {
12         title1:"Vue.js Demo"
13       }
14     },
15     props:{
16       title:{
17         type:String
18       }
19     },
20     methods:{
21       changeTitle:function(){
22         this.$emit("titleChanged","子向父组件传值");
23       }
24     }
25   }
26 </script>
27 
28 <style scoped>
29 header{
30   background: pink;
31   padding: 10px;
32 }
33 h1{
34   color: #222;
35   text-align: center;
36   }
37 </style>
复制代码

  Footer.vue文件:

复制代码
 1 <template>
 2   <footer>
 3     <p>{{copyright}}</p>
 4   </footer>
 5 </template>
 6 
 7 
 8 <script>
 9   export default {
10     data () {
11       return {
12         copyright:"Copyright 2018 Vue Demo"
13       }
14     }
15   }
16 </script>
17 
18 <style scoped>
19   footer{
20     background: #666;
21     padding: 6px;
22   }
23   footer p{
24     color: pink;
25     text-align: center;
26   }
27 </style>
复制代码

  User.vue文件:

复制代码
 1 <template>
 2   <div class="users">
 3     <ul>
 4       <li v-for="user in users"
 5           @click="user.show = !user.show">
 6         <h2 >{{user.name}}</h2>
 7         <h3 v-show="user.show">{{user.Position}}</h3>
 8       </li>
 9     </ul>
10   </div>
11 </template>
12 
13 <script>
14   export default {
15     name: 'users',
16     // props:['users']
17     props:{
18       users:{
19         type:Array,
20         required:true
21       }
22     }
23   }
24 </script>
25 
26 <style scoped>
27 .users{
28   width: 100%;
29   max-width: 1200px;
30   margin:40px auto;
31   padding: 0 20px;
32   box-sizing: border-box;
33 }
34 ul{
35    display: flex;
36   flex-wrap: wrap;
37   list-style-type: none;
38   padding: 0;
39   }
40 li{
41   flex-grow: 1;
42   flex-basis: 200px;
43   text-align: center;
44   padding: 30px;
45   border: 1px solid #666;
46   margin: 10px;
47 }
48 </style>
复制代码

  然后在App.vue文件中加入导航;

App.vue文件:

复制代码
 1 <!--模板-->
 2 <template>
 3   <div id="app">
 4     <ul>
 5       
 7       <li> <router-link to="/">Home</router-link> </li>
 8       <li> <router-link to="/helloworld">Hello</router-link> </li>
9 </ul>
10 <router-view></router-view> 11 </div> 12 </template> 13 <!--行为--> 14 <script> 15 16 export default { 17 name: 'App', 18 data(){ 19 return { 20 } 21 }, 22 methods:{ 23 } 24 } 25 </script> 26 <!--样式--> 27 <style > 28 29 </style>
复制代码


  这里如果使用 <a href=""></a> 标签,点击时候会跳转和刷新页面,而使用路由 <router-link to=""></router-link> 则不会,to跟a标签里的href是一样的.

 

 

文章摘自:https://www.cnblogs.com/jin-zhe/p/8317657.html,并添加部分内容。

posted @ 2018-08-03 09:32  甘劭  阅读(249)  评论(0编辑  收藏  举报