## 基本用法1
用 Vue.js + vue-router 创建单页应用,是非常简单的。使用 Vue.js ,我们已经可以通过组合组件来组成应用程序,当你把 vue-router 添加进来,Vue-router的基本作用就是将每个路径映射到对应的组件,并通过修改路由进行组件间的切换。
### 第一个单页面应用
现在我们以一个简单的单页面应用开启vue-router之旅,这个单页面应用有3个路径:/home 、list,/about,与这两个路径对应的是3个组件Home、List和About。
![](https://box.kancloud.cn/5cce201d2264d5ac82471b3874f67d17_512x346.png)
**HTML**
>[info]1.首先引入vue.js和vue-router.js:
~~~
<script src="../lib/vue.js" type="text/javascript" charset="utf-8"></script>
<script src="../lib/vue-router.js" type="text/javascript" charset="utf-8"></script>
~~~
>[info]2.使用 使用 router-link 组件来导航.
~~~
<ul class="nav navbar-nav">
<!-- 使用 router-link 组件来导航. -->
<!-- 通过传入 `to` 属性指定链接. -->
<!-- <router-link> 默认会被渲染成一个 `<a>` 标签 -->
<li> <router-link to="/home" >Home</router-link></li>
<li> <router-link to="/list" >List</router-link></li>
<li> <router-link to="/about">About</router-link></li>
</ul>
~~~
>[info]3.使用<router-view>标签
~~~
<!-- 路由出口 -->
<!-- 路由匹配到的组件将渲染在这里 -->
<router-view></router-view>
~~~
**JavaScript**
>[info]1.创建组件
在js中创建3个组件Home、List、About:
- 创建组件 Home
~~~
var Home ={
template: `<div class="jumbotron">
<h1>{{msg}}</h1>
<p>...</p>
<p><a class="btn btn-primary btn-lg" href="#" role="button">Learn more</a></p>
</div>`,
data: function() {
return {
msg: 'Hello, vue router!'
}
}
}
~~~
- 创建组件 List
~~~
var List ={
template: `<div class="list-group">
<a href="#" class="list-group-item" v-for="item in msg">
{{item.title}}
</a>
</div>`,
data: function() {
return {
msg:[
{title:'Dapibus ac facilisis in'},
{title:'Morbi leo risus'},
{title:'Porta ac consectetur ac'},
{title:'Vestibulum at eros'},
{title:'Cras justo odio'},
]
}
}
}
~~~
- 创建组件 About
~~~
var About = {
template: '<div><h1>About</h1><p>This is the tutorial about vue-router.</p></div>'
}
~~~
>[info]2.定义路由,每个路由应该映射一个组件。
~~~
const routes = [
{ path: '/home', component: Home },
{ path: '/list', component: List },
{ path: '/about', component: About }
]
~~~
>[info] 3.创建 router 实例,然后传 `routes` 配置
~~~
const router = new VueRouter({
routes // (缩写)相当于 routes: routes
})
~~~
>[info]4.创建和挂载根实例。
记得要通过 router 配置参数注入路由,从而让整个应用都有路由功能
~~~
const app = new Vue({
router
}).$mount('#app')
~~~
现在,应用已经启动了!
![](https://box.kancloud.cn/ca4c81655d24ed52b7fe048ef0a09f11_777x509.gif)
-------
>[success]预览:http://vue.taoge1024.com/Vue-router/01/router01.html
git地址:
-----------------------
>[danger]上述代码在浏览器打开时,内容区域为空,只有点击切换的时候才有内容,是因为我们没有定义默认路由,定义默认路由,同样比较简单,只需要在映射路由时,指定一个根目录,指定要显示哪个组件。
~~~
const routes = [
{ path: '/', component: Home },//指定默认进来的组件
{ path: '/home', component: Home },
{ path: '/list', component: List },
{ path: '/about', component: About }
]
~~~
-------------------
>[success]预览:http://vue.taoge1024.com/Vue-router/01/router02.html
git地址:
- 前端新手村
- 前言
- 第1章 遇见Vue.js
- 第一个Vue.js程序
- vue尝鲜
- 第2章 概念理解
- 渐进式框架
- 虚拟DOM
- MVVM模式
- MVX模式是什么
- 第3章 Vue基础概览
- 第4章 Vue内置指令详解
- vue-text
- vue-html
- v-show
- v-if
- v-else
- v-else-if
- v-for
- v-on
- v-bind
- v-model
- v-pre
- v-cloak
- v-once
- 第5章 基础demo小练习
- 图书管理系统
- 页面布局
- 列表渲染
- 功能实现
- 基于BootStrap+Vuejs实现用户信息表
- 功能描述
- 布局实现
- 星座判断
- 第6章 组件
- 什么是组件
- 使用组件
- Prop
- 自定义事件
- 使用Slot分发内容
- 动态组件
- 杂项
- 第7章-过渡
- 过渡效果
- 概述
- 单元素/组件的过渡
- 初始渲染的过渡
- 多个元素的过渡
- 多个组件的过渡
- 列表过渡
- 可复用的过渡
- 动态过渡
- 过渡状态
- 状态动画与watcher
- 动态状态转换
- 通过组件组织过渡
- Render函数
- 基础
- createElement参数
- 使用JavaScript代替模板功能
- JSX
- 函数化组件
- 模板编译
- 自定义指令
- 简介
- 钩子函数
- 钩子函数参数
- 函数简写
- 对象字面量
- Vuex状态管理
- Vuex是什么?
- Vuex的安装
- Vuex起步
- data的替代品-State和Getter
- 测试Getter
- Action-操作的执行者
- 测试Action
- 只用Mutation修改状态
- 测试Mutations
- Vuex的基本结构
- 子状态和模块
- 用服务分离外部操作
- Vue-router
- Vue-router是什么
- Vue-router安装
- 基本用法1
- 基本用法2
- Vue-cli
- Vue中的Node.js
- Vue中的npm、cnpm
- Vue中的webpack
- 安装
- 基本使用
- 模板
- 全局API
- Vue.extend
- Vue.nextTick
- Vue.set
- Vue.delete
- Vue.directive
- Vue.filter
- Vue.component
- Vue.use
- Vue.mixin
- Vue.compile
- 附录
- 相关网站
- 尤雨溪
- 第10章 webpack
- webpack安装
- webpack基本使用
- webpack命令行
- webpack配置文件
- 单页面应用SPA
- 第1章 Vue.js简介
- 1.1 Vue.js简介
- 1.1.1 Vue.js是什么
- 1.1.2 为什么要用Vue.js
- 1.1.3 Vue.js的发展历史
- 1.1.4 Vue.js与其他框架的区别
- 1.2 如何使用Vue.js
- 1.2.1 第一个Vue.js程序
- 1.2.2 Vue.js小尝鲜
- 1.3 概念详解
- 1.3.1 什么是渐进式框架
- 1.3.2 虚拟DOM是什么
- 1.3.3 如何理解MVVM
- 第2章 基础概览
- 2.1 Vue实例
- 2.1.1 构造器
- 2.1.2 属性与方法
- 2.1.3 实例生命周期
- 2.1.4 生命周期图示
- 2.2 模板语法
- 2.2.1 插值
- 2.2.2 指令
- 2.2.3 过滤器
- 2.2.4 缩写
- 第3章 Class与Style的绑定
- 第4章 模板渲染
- 第5章 事件详解
- 第6章 表单控件绑定
- 第7章 指令详解
- 7.1 内部指令
- 7.2 自定义指令
- 7.3 指令的高级选项
- 第8章 计算属性
- 第9章 过滤器
- 第10章 组件
- 10.1 什么是组件
- 10.2 注册组件
- 10.3 组件选项
- 10.4 组件间的通信
- 10.5 内容分发
- 10.6 动态组件