Vue.js系列之vue-router(上)(3)

说明:

我们项目现在用的是:vue2.0 + vue-cli + webpack + vue-router2.0 + vue-resource1.0.3 

如果大家在实践的过程中与本文所说的内容有较大区别的话看看是不是版本问题。

本文是一系列文章,在我对Vue有了更深刻的理解认识之后会对文章及时进行修改或更正。欢迎大家批评指出错误。以下是已完成的文章列表。

 1.Vue.js系列之项目搭建(1)

 2.Vue.js系列之项目结构说明(2)


概述

Vue非常适用于实践单页面应用程序也就是平时大家说的比较多的SPA(single page application),这点应该了解过Vue的应该都知道吧。一般的单页面应用是基于路由或页面之间的链接来形成的,Vue是基于路由和组件的,所以我们今天就来了解下vue-router。vue-router是Vue.js官方的路由插件,它和vue.js深度集成,用于设定访问路径,并将路径和组件映射起来,我们给每个组件一个路由地址,跳转路由相当于组件切换。vue-router的内容还是比较多的,这里我只分享我自己项目中用到的地方,其他地方大家可以看文档啦。

vue-router官网:http://router.vuejs.org/zh-cn/(中)

英文官网你知道啦,直接去掉后面的"zh-cn/"就好了。


开始使用vue-router

这里我假设大家之前都用模块工程的方式实践了一个vue Demo,在此基础上我们添加vue-router。
1.安装
[html]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. npm install vue-router  
2.在项目main.js中安装路由插件
[javascript]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. import Vue from 'vue'  
  2. import VueRouter from 'vue-router'  
  3. Vue.use(VueRouter)  
3.在组件中使用路由
先看下路由跳转的效果吧,大家注意看地址栏变化哈。
路由效果图

下面这个tabBar就是一个组件(偷偷告诉你,在微信小程序中,这个功能直接配置app.json文件就好了

每个tab点击时路由地址会相应变化,其实是渲染相应的组件,具体我们来看代码。

footer.vue组件

[html]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. <template>  
  2.     <div class="footer">  
  3.         <div class="readType" v-if="readType.count">{{readType.count}}</div>  
  4.         <ul class="main-nav">  
  5.             <li>  
  6.                 <router-link to="/home">  
  7.                     <i class="icon-nav icon-nav1"></i><span>首页</span>  
  8.                 </router-link>  
  9.             </li>  
  10.             <li>  
  11.                 <router-link to="/quan" v-bind:class="{rrouter:activ}">  
  12.                     <i class="icon-nav icon-nav2"></i><span>学友圈</span>  
  13.                 </router-link>  
  14.             </li>  
  15.             <li>  
  16.                 <router-link to="/friend">  
  17.                     <i class="icon-nav icon-nav3"></i><span>学友</span>  
  18.                 </router-link>  
  19.             </li>  
  20.             <li>  
  21.                 <router-link to="/find">  
  22.                     <i class="icon-nav icon-nav4"></i><span>发现</span>  
  23.                 </router-link>  
  24.             </li>  
  25.             <li>  
  26.                 <router-link to="/mine">  
  27.                     <i class="icon-nav icon-nav5"></i><span>我的</span>  
  28.                 </router-link>  
  29.             </li>  
  30.         </ul>  
  31.     </div>  
  32. </template>  


这里有几点需要知道:

1.使用 router-link 组件来导航.

2.通过传入 `to` 属性指定链接.

3.<router-link> 默认会被渲染成一个 `<a>` 标签


路由出口

我们前面说了,路由跳转就是相应组件在渲染,那么渲染的内容是怎么显示也页面中的呢,那就是路由出口'<router-view></router-view>'做的事了,路由匹配到的组件将渲染在这里。

路由出口我们可以设置在当前组件中也可以设置在其他组件中,项目中我们就将所有组件都渲染在最大的容器App.vue组件中(我们项目中App组件只作为渲染容器)。

[html]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. <template>  
  2.   <div id="app">  
  3.     <router-view></router-view>  
  4.   </div>  
  5. </template>  

JavaScript

定义路由文件可以直接写在main.js文件中,也可以新建一个js文件,因为我们的组件比较多,所以单独把路由拿出来写了一个router.js文件。

[javascript]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. // 0. 如果使用模块化机制编程,进入Vue和VueRouter,要调用 Vue.use(VueRouter)  
  2. import Vue from 'vue'  
  3. import VueRouter from 'vue-router'  
  4. Vue.use(VueRouter)  
  5.   
  6. // 1. 定义(路由)组件。  
  7. // 可以从其他文件 import 进来,我们一般都是建好了组件再来写路由的  
  8. // 所以就会有好多这样的语句。  
  9. import home form "./components/home"  
  10. import login form "./components/login"  
  11.   
  12. // 2. 定义路由  
  13.   routes: [ //这里跟1.x有挺大区别,有接触的自己看清楚哦  
  14.     {  
  15.       path: '/',    //浏览器网路请求走通之后默认就会去找域名下的根目录,  
  16.       name: 'home'//所以我们就把这个组件作为默认首页  
  17.       component: home  
  18.     },  
  19.     {  
  20.       path: '/login',  
  21.       name: 'login',  
  22.       component: login  
  23.     }  
  24.    ]  
  25.   
  26. // 3. 创建 router 实例,然后传 `routes` 配置  
  27. // 你还可以传别的配置参数, 不过先这么简单着吧。  
  28. const router = new VueRouter({      //你就当const是var  
  29.   routes  
  30. //(缩写)相当于 routes: routes  
  31. })  
  32.   
  33. // 4. 创建和挂载根实例。  
  34. // 记得要通过 router 配置参数注入路由,  
  35. // 从而让整个应用都有路由功能  
  36. const app = new Vue({  
  37.   router  
  38. }).$mount('#app')  
  39. // 现在,应用已经启动了!  

总结

上篇先分享到这里,主要了解了有以下几点:
1.vue-router的安装和使用
2.在组件模板中的书写格式
3.知道了路由出口
4.如何定义一个路由
5.创建路由实例和挂载实例

下篇我将给大家继续分享路由的其他用法(项目中用到的):
1.如何实现当前页激活,tab标签同时也激活,即active-class
2.路由跳转时添加过渡动效
3.路由传参及命名路由
4.实现资源懒加载
5.编程式导航
6.router-link的其他表现形式
7.Router构造详细配置

内容有点多,可能还要再分细一点,写详细点。但还是想把自己遇到过的问题,用到的知识点通过自己的理解分享出来。


明天还是要用markDown来写,默认的这个编辑器排版实在太累了,经常出问题,但是我的markDown不知道为什么,光标经常会自动换行,不知道有没有朋友遇到过,能否解答一下。


评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值