博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
vue 2 + vue-router 2 实现SPA
阅读量:6671 次
发布时间:2019-06-25

本文共 2896 字,大约阅读时间需要 9 分钟。

使用 Vue.js 时,我们就已经把组件组合成一个应用了,当我们要把 vue-router 加进来,只需要配置组件和路由映射,然后告诉 vue-router 在哪里渲染它们。

先来看一下官方提供的最简单的例子:

HTML

Hello App!

Go to Foo
Go to Bar

从HTML文件里面我们需要学会的是:

  1. <router-link>标签是我们要跳转的链接,to=""是必须的属性,双引号中的内容是我们接下来在JS文件中定义的路由path。
  2. <router-view>标签是展示我们匹配到的组件的区域。

JavaScript

// 0. 如果使用模块化机制编程,导入Vue和VueRouter,要调用 Vue.use(VueRouter)// 1. 定义(路由)组件。// 也可以从其他文件 import 进来const Foo = { template: '
foo
' }const Bar = { template: '
bar
' }// 2. 定义路由// 每个路由应该映射一个组件。 其中"component" 可以是// 通过 Vue.extend() 创建的组件构造器,// 或者,只是一个组件配置对象。const routes = [ { path: '/foo', component: Foo }, { path: '/bar', component: Bar }]// 3. 创建 router 实例,然后传 `routes` 配置// 你还可以传别的配置参数, 不过先这么简单着吧。const router = new VueRouter({ routes // (缩写)相当于 routes: routes})// 4. 创建和挂载根实例。// 记得要通过 router 配置参数注入路由,// 从而让整个应用都有路由功能const app = new Vue({ router}).$mount('#app')// 现在,应用已经启动了!

JavaScript文件主要做的事情是:

  1. 定义路由列表,即routes。
  2. 创建router实例及router配置,即router。
  3. 创建和挂载根实例。

以上只是教我们用最简单的方法使用vue-router。但实际开发过程中,首先我们的vue组件显然不会只有一个template模板这么简单,会用到vue的;其次我们通常会希望<router-view>的范围是整个页面,而不是像现在这样一直有几个碍眼的导航存在于页面上,这就需要先定义好默认状态下<router-view>显示的内容。

既然是单页应用(SPA),那么整个项目有以下三个文件是必要的:

  1. 一个html文件:index.html
  2. 一个webpack打包时的入口js文件:main.js
  3. 一个根vue组件,作为其他组件的挂载点:app.vue

另外还有两个自定义组件:homepage.vue和chat.vue。我们希望的结果是他们之间互相跳转。

下面看下这几个文件的具体内容:

index.html

  
Vue.js v2

main.js

这里我们选择把路由配置也写到main.js中,你也可以写到一个单独的router.js中再引入到main.js中。

//引入vue、vue-router和根组件app.vueimport Vue from 'vue'import VueRouter from 'vue-router'import App from './components/app.vue'Vue.use(VueRouter)// 引入自定义组件import HomePage from './components/homepage.vue'import Chat from './components/chat/chat.vue'//定义路由const routes = [    //这里 path: '/' 代表应用首页显示的内容    { path: '/', component: HomePage },    { path: '/chat', component: Chat }];//创建router实例const router = new VueRouter({  //mode指定路由模式,默认'hash',另一种可选的模式是'history'  mode: 'hash',  routes,});new Vue({  el: '#application',  router,  render: h => h(App) //用render函数渲染引入的组件App.vue到index.html中的#application元素中})

app.vue

自定义组件 homepage.vue

这个组件的内容也是进入应用默认展示的页面内容。

自定义组件 chat.vue

写完后你会发现这两个页面是互相跳转的,没错,就是这样。

一般我们会把路由信息routes提取到一个单独的文件中,像这样:

路由信息提取到单独文件中 route-config.js:

import HomePage from './components/homepage.vue'import Chat from './components/chat/chat.vue'export default [    {         path: '/',        component: HomePage     },    {         path: '/chat',         component: Chat     }];

然后在main.js中引入: import routes from './route-config.js' 就可以了。

参考文献:

  1. vue-router 2官方文档:
  2. Vue-router2.0学习笔记:
  3. vue2.0构建单页应用最佳实战:
  4. 一个完整的vue应用 ( vuex+vue-router ) 起手:

转载地址:http://malxo.baihongyu.com/

你可能感兴趣的文章
由浅入深CIL系列:2.CIL的基本构成+CIL操作码速记表+CIL操作码大全速查
查看>>
Spark RDD概念学习系列之Spark的算子的作用(十四)
查看>>
Godaddy域名申请及设置
查看>>
Java反射
查看>>
PostgreSQL的notify 与listen (五)
查看>>
PowerDesigner从Sqlserver中反转为带注释的字典及快捷键操作
查看>>
怎样在Android实现桌面清理内存简单Widget小控件
查看>>
分享10款非常有用的 Ajax 插件
查看>>
集群工具ansible使用方法
查看>>
Python黑帽编程2.6 模块
查看>>
__toString()方法
查看>>
前端魔法堂:解秘FOUC
查看>>
远端访问MySQL
查看>>
今天写shader流光效果,shader代码少了个括号,unity shader compiler卡死且不提示原因...
查看>>
SQL Server中的执行引擎入门
查看>>
转]使用Python获得本机IP地址
查看>>
万能清除浮动样式
查看>>
C++/C, Java学习资料
查看>>
f(f(x))=-x, x是Int32,这类函数的抽象理解
查看>>
extjs Accordion 怎样把展开符号:加号(+)放在左边?
查看>>