对于单页应用,官方提供了vue-router进行路由跳转的处理,本篇主要也是基于其官方文档写作而成。
安装
基于传统,我更喜欢采用npm包的形式进行安装。
npm install vue-router --save
当然,官方采用了多种方式进行安装,包括bower,cdn等。
基本用法
在HTML文档中使用,只需要利用v-link这个directive就行了,如:
<a v-link="{path: '/view-a'}">Go to view-a</a>
ps: v-link还支持activeClass用于指定链接活跃时的css样式。replace属性为true的时候可以让链接在跳转的时候不会留下历史记录。
而在ES5中使用,需要先创建路由器实例,随后传入配置参数即可,如:
var router = new VueRouter();
router.map({
'/view-a': {
component: ViewA
},
'/view-b': {
component: ViewB
}
});router.start(App, '#app');
以上定义的路由器规则,采用映射到一个组件的方式,最后启动应用的时候,挂载到#app的元素上。
当然,如果你想采用ES6的语法进行配置,也是很容易做到的:
先建立一个路由器模块,主要进行配置和绑定相关信息
import Vue from 'vue';
import VueRouter from 'vue-router';
Vue.use(VueRouter);
const router = new VueRouter(); //这里可以带有路由器的配置参数
router.map({
'/view-a': {
component: ViewA
},
'/view-b': {
component: ViewB
}
});export default router; //将路由器导出
在app.js入口启动文件中启用该路由器
import Vue from 'vue';
import router from './routers';router.start(App, '#app');
嵌套路由
如果想要使用嵌套路由,如/a/b则可以更新路由配置
router.map({
'/a': {
component: A,
subRoutes: {
'/b': {
component: B
}
}
}
});
同时,你需要在组件A和组件B中使用<router-view>,如:
<div id="app">
<router-view></router-view>
</div>
组件A中,使用嵌套的外链
<div id="A">
<h1>
This is component A
</h1>
<router-view></router-view>
</div>
路由器将自动渲染对应的组件以及更新路由信息。
其中<router-view>可以传递props,支持v-ref,同时也可以使用v-transition和transition-mode来获得场景切换效果,被渲染的组件将注册到父级组件的this.$对象上。
路由对象和路由匹配
路由对象,即$router会被注入每个组件中,可以利用它进行一些信息的获取。如
属性
说明
$route.path
当前路由对象的路径,如'/view/a'
$rotue.params
关于动态片段(如/user/:username)的键值对信息,如{username: 'paolino'}
$route.query
请求参数,如/foo"{name: 'user', params: {userId: 1}">This is a user whose id is 1</a>
还可以使用router.go()
router.go({name: 'user', params: {userId: 1}});
最终都会匹配到/user/1这条路径上
路由选项
路由选项名
默认值
作用
hashbang
true
将路径格式化为#!开头
history
false
启用HTML5 history模式,可以使用pushState和replaceState来管理记录
abstract
false
使用一个不依赖于浏览器的浏览历史虚拟管理后端。
transitionOnLoad
false
初次加载是否启用场景切换
saveScrollPosition
false
在启用html5 history模式的时候生效,用于后退操作的时候记住之前的滚动条位置
linkActiveClass
"v-link-active"
链接被点击时候需要添加到v-link元素上的class类,默认为active
如,我想采用一个有路径格式化并启用Html5 history功能的路由器,则可以在路由器初始化的时候,指定这些参数:
var router = new VueRouter({
hashbang: true,
history: true
});
这里只是做了一些简单的介绍,更多选项其参考官方文档http://router.vuejs.org/zh-cn/。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
Vue,router
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。