深入理解Vue router的部分高级用法


Posted in Javascript onAugust 15, 2018

今天要介绍的是路由元信息,滚动行为以及路由懒加载这几个的使用方法。

1.路由元信息

什么是路由元信息,看看官网的解释,定义路由的时候可以配置 meta 字段可以匹配meta字段,那么我们该如何使用它,一个简单的例子,改变浏览器title的值。下面上代码。

//简单的我就不写了直接上解决方案
import Vue from 'vue'
import Router from 'vue-router'
import Login from '../login/Login'
import Home from '../pages/Home'
export default new Router({
  mode: 'history',
  routes: [
    {path: 'home', name: 'Home', component: Home,meta:{title:"主页"}}
    {path: 'login', name: 'Login', component: Login,meta:{title:"登录"}}
  ]
})
//可以在跳转之前判断跳转的组件的名字并用window.document.title赋值
Router.beforeEach((to,from,next) => {
  window.document.title=to.meta.title
})

上面的是不是看上去很简单呢,但是它并不简单,我只是举了一个比较小的例子罢了。还要看大家怎么活学活用这样才好,但是我强调几点需要注意的

第一点就是这个beforeEach页面跳转之前调用,好处是比如想要改变title的值不会显得太突兀,可以直接替换。

第二点afterEach这个不用我说了吧这个是在组件跳转之后调用比较适用于返回页面之前浏览过的区域或者是让页面返回顶部的操作。

2.滚动行为

想必各位同学应该知道我要讲些什么了没错就是页面的前进和后退时的滚动事件,怎么实现呢,有两种实现方式,先看代码。

//刚才我说过的方法直接使用afterEach方法去实现组件的scrollTo归零
Router.afterEach((to,from,next) => {
  window.scrollTo(0,0)
})

下面是真正的回滚事件可以看看

//简单的我就不写了直接上解决方案
import Vue from 'vue'
import Router from 'vue-router'
import Login from '../login/Login'
import Home from '../pages/Home'
export default new Router({
  mode: 'history',
  routes: [
    {path: 'home', name: 'Home', component: Home,meta:{title:"主页"}}
    {path: 'login', name: 'Login', component: Login,meta:{title:"登录"}}
  ],
  //有两种小的方式进行回滚
  //{ x: number, y: number }
  //{ selector: string, offset? : { x: number, y: number }}
  //第二种方式仅适用于(offset 只在 2.6.0+ 支持)
  scrollBehavior (to, from, savedPosition) {
  console.log(savedPosition)
  return { x: 0, y: 0 }
  }
})

上面我们介绍了scrollBehavior的回滚方法或者说是scrollBehavior的滚动行为,但是想必大家可能对这种方法还有些不太理解,下面我们看看官网是怎么讲解的,使用前端路由,当切换到新路由时,想要页面滚到顶部,或者是保持原先的滚动位置,就像重新加载页面那样。 vue-router 能做到,而且更好,它让你可以自定义路由切换时页面如何滚动。没错这个方法就是scrollBehavior滚动行为。另外需要注意: 这个功能只在支持 history.pushState 的浏览器中可用。更多的使用方法可以去官网去看看。

3.路由懒加载

或许不应该叫路由懒加载应该叫按需加载我觉着是更合适的。不解释以后用多了你们就会理解。下面上代码。

//代码很简单看看就知道了,下面只贴部分代码
{path:'homepages',name:'Homepages',component:homepages,resolve}

没错只要使用resolve就能实现按需加载的要求,是不是很简单,但是resolve还有很多其他使用方式建议去官网看看。另外诸如go(),history等方法的使用还是去官网上看看自己写出来理解会更快。

总结

以上所述是小编给大家介绍的Vue router的部分高级用法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
js option删除代码集合
Nov 12 Javascript
javascript学习笔记(二) js一些基本概念
Jun 18 Javascript
探索Emberjs制作一个简单的Todo应用
Nov 07 Javascript
js优化针对IE6.0起作用(详细整理)
Dec 25 Javascript
jQuery中:first选择器用法实例
Dec 30 Javascript
Bootstrap select下拉联动(jQuery cxselect)
Jan 04 Javascript
vue实现百度下拉列表交互操作示例
Mar 12 Javascript
JavaScript的Proxy可以做哪些有意思的事儿
Jun 15 Javascript
layui 点击重置按钮, select 并没有被重置的解决方法
Sep 03 Javascript
JavaScript对象原型链原理解析
Jan 22 Javascript
微信小程序完美解决scroll-view高度自适应问题的方法
Aug 08 Javascript
javascript实现倒计时关闭广告
Feb 09 Javascript
JS打印彩色菱形的实例代码
Aug 15 #Javascript
layui点击按钮添加可编辑的一行方法
Aug 15 #Javascript
layui 优化button按钮和弹出框的方法
Aug 15 #Javascript
jQuery实现参数自定义的文字跑马灯效果
Aug 15 #jQuery
Webpack 4.x搭建react开发环境的方法步骤
Aug 15 #Javascript
React+Webpack快速上手指南(小结)
Aug 15 #Javascript
layui从数据库中获取复选框的值并默认选中方法
Aug 15 #Javascript
You might like
中国收音机工业发展史
2021/03/02 无线电
php学习笔记(三)操作符与控制结构
2011/08/06 PHP
深入php define()函数以及defined()函数的用法详解
2013/06/05 PHP
PHP调用wsdl文件类型的接口代码分享
2014/11/19 PHP
php字符串截取函数用法分析
2014/11/25 PHP
smarty内置函数foreach用法实例
2015/01/22 PHP
YII2 实现多语言配置的方法分享
2017/01/11 PHP
ThinkPHP5 验证器的具体使用
2018/05/31 PHP
php判断某个方法是否存在函数function_exists (),method_exists()与is_callable()区别与用法解析
2020/04/20 PHP
Function.prototype.call.apply结合用法分析示例
2013/07/03 Javascript
调用DOM对象的focus使文本框获得焦点
2014/02/19 Javascript
node.js中的buffer.Buffer.isEncoding方法使用说明
2014/12/14 Javascript
Eclipse引入jquery报错如何解决
2015/12/01 Javascript
BootStrap 智能表单实战系列(二)BootStrap支持的类型简介
2016/06/13 Javascript
Bootstrap 实现查询的完美方法
2016/10/26 Javascript
vue-cli+webpack项目 修改项目名称的方法
2018/02/28 Javascript
Vue项目全局配置页面缓存之按需读取缓存的实现详解
2018/08/01 Javascript
vuejs2.0运用原生js实现简单拖拽元素功能
2020/08/21 Javascript
详解Vue.directive 自定义指令
2019/03/27 Javascript
jquery实现烟花效果(面向对象)
2020/03/10 jQuery
简单谈谈python中的多进程
2016/11/06 Python
浅谈python socket函数中,send与sendall的区别与使用方法
2017/05/09 Python
python 获取当天每个准点时间戳的实例
2018/05/22 Python
对python 通过ssh访问数据库的实例详解
2019/02/19 Python
python模拟点击网页按钮实现方法
2020/02/25 Python
说一下mysql, oracle等常见数据库的分页实现方案
2012/09/29 面试题
大一新生学期自我评价
2014/04/09 职场文书
2014国庆节标语口号
2014/09/19 职场文书
六查六看心得体会
2014/10/14 职场文书
2014年置业顾问工作总结
2014/11/17 职场文书
庆祝教师节活动总结
2015/03/23 职场文书
初中同学会致辞
2015/08/01 职场文书
2016同学毕业寄语大全
2015/12/04 职场文书
《蚂蚁和蝈蝈》教学反思
2016/02/22 职场文书
中秋节作文(五年级)之关于月亮
2019/09/11 职场文书
《群青的幻想曲》京力秋树角色PV公开
2022/04/08 日漫