当前位置: 首页 > news >正文

虎门网站建设服务商微信公众号运营

虎门网站建设服务商,微信公众号运营,学python能干嘛,移动网站 案例一、vue-router路由变化侦测 1.1 上一遍文章中,介绍了vue-router 的install 函数的内部实现,知道了能在this中访问$router 和视图更新的机制,文章链接终于把 vue-router 运行原理讲明白了(一)!&#xff01…

一、vue-router路由变化侦测

1.1 上一遍文章中,介绍了vue-router 的install 函数的内部实现,知道了能在this中访问$router 和视图更新的机制,文章链接终于把 vue-router 运行原理讲明白了(一)!!!
下面开始介绍上一遍文章遗留的疑惑点,_route 属性值如何变化,进行剖析

 Vue.util.defineReactive(this, '_route', this._router.history.current)

1.2 我们找到 vue-router 源码的 src目录下的 router.js 文件 ,里面有一个init方法,还记得我们上一遍文章中,install 方法中,在根组件调用了这个init 方法,代码如下(经过删减,要完整代码请阅读源码)
代码中两个重要地方,history.transitionTohistory.listen

init (app: any /* Vue component instance */) {const history = this.historyif (history instanceof HTML5History || history instanceof HashHistory) {const handleInitialScroll = routeOrError => {const from = history.currentconst expectScroll = this.options.scrollBehaviorconst supportsScroll = supportsPushState && expectScrollif (supportsScroll && 'fullPath' in routeOrError) {handleScroll(this, routeOrError, from, false)}}const setupListeners = routeOrError => {history.setupListeners()handleInitialScroll(routeOrError)}history.transitionTo(history.getCurrentLocation(),setupListeners,setupListeners)}history.listen(route => {this.apps.forEach(app => {app._route = route})})}

1.3 history有三种值,分别为HTML5History(对应的是 路由的history模式)
还有hashabstract

 case 'history':this.history = new HTML5History(this, options.base)breakcase 'hash':this.history = new HashHistory(this, options.base, this.fallback)breakcase 'abstract':this.history = new AbstractHistory(this, options.base)breakdefault:if (process.env.NODE_ENV !== 'production') {assert(false, `invalid mode: ${mode}`)}

在1.2 中,init 方法执行了history 的 transitionTo 方法传入了三个参数,为当前路由路径和setupListeners

history.transitionTo(history.getCurrentLocation(),setupListeners,setupListeners)

1.4 下面我们找到transitionTo,其具体位置在 src 下面的history目录的base.js 文件,重点是 执行了confirmTransition 方法,第二个参数是一个回调方法,等异步组件准备完毕,就执行,其中有一个重要步骤,就是执行 this.updateRoute(route)

transitionTo (location: RawLocation,onComplete?: Function,onAbort?: Function) {this.confirmTransition(route,() => {this.updateRoute(route)onComplete && onComplete(route)this.ensureURL()this.router.afterHooks.forEach(hook => {hook && hook(route, prev)})},err => {})}

updateRoute 代码如下,他会判断cb存不存在,存在才执行该函数,那么这个cb到底是啥

updateRoute (route: Route) {this.current = routethis.cb && this.cb(route)}

1.5 在base.js 文件中,找到一个方法如下,看起来好像在哪里见过,没错啦,就是在执行init方法时候,

// base.jslisten (cb: Function) {this.cb = cb}

该方法就在 router.js 的init 方法中,后于 history.transitionTo 执行,因此,根组件是不会执行 app._route = route 这个方法

 // router.js 的 init方法中执行  history.listenhistory.listen(route => {this.apps.forEach(app => {app._route = route})})

那执行这个方法有啥用呢,我们在1.1 中见过,一旦该值发生变化,便会通知vue更新视图。那么,什么时候才会执行这个方法呢

二、_route 变化时机

2,1 在 history.transitionTo 中 还有一个重要的方法 setupListeners

history.transitionTo(history.getCurrentLocation(),setupListeners,setupListeners)

setupListeners 代码如下,

 const setupListeners = routeOrError => {history.setupListeners()handleInitialScroll(routeOrError)}

history.setupListeners() 具体位置为 html5.js 的 setupListeners ,重要代码如下,我们监听popstate 事件,(history模式下触发,hash模式触发haschange)

  window.addEventListener('popstate', handleRoutingEvent)

具体解释如下
当活动历史记录条目更改时,将触发popstate事件。如果被激活的历史记录条目是通过对history.pushState()的调用创建的,或者受到对history.replaceState()的调用的影响,popstate事件的state属性包含历史条目的状态对象的副本。

也就是触发 pushState或者 history.replaceState就会触发 popstate 事件,然后执行 handleRoutingEvent 函数,他会执行 this.transitionTo 函数,也就是执行 updateRoute 函数
就是说 我们一旦执行history.pushState或者 history.replaceState 就会更新_route 的值

三、pushState或者 replaceState执行机制

3.1 我们在route的push方法中发现如下代码,是不是很眼熟,就是我们平时调用的 this.$router.push 代码的执行逻辑,这个方法中 执行了history.push

 push (location: RawLocation, onComplete?: Function, onAbort?: Function) {console.log("执行push逻辑",...arguments)// $flow-disable-lineif (!onComplete && !onAbort && typeof Promise !== 'undefined') {return new Promise((resolve, reject) => {this.history.push(location, resolve, reject)})} else {this.history.push(location, onComplete, onAbort)}}

3.2 我们在html5.js 中找到history的push方法,其中就执行 pushState

push (location: RawLocation, onComplete?: Function, onAbort?: Function) {const { current: fromRoute } = thisthis.transitionTo(location, route => {pushState(cleanPath(this.base + route.fullPath))handleScroll(this.router, route, fromRoute, false)onComplete && onComplete(route)}, onAbort)}

也就是说,当我们调用this.$router.push 或者replace 时候就会触发 popstate 事件的监听,从而触发_route 更新,最后通知vue更新视图,一切新的视图就会展现在我们面前啦

http://www.hengruixuexiao.com/news/9177.html

相关文章:

  • 京东不让卖网站制作么seo教程搜索引擎优化
  • 做网站点击软件如何做好网络营销推广
  • 群辉做网站服务器pythonsteam交易链接在哪看
  • 郑州富士康电子厂郑州搜索引擎优化公司
  • 制作网站能赚钱吗如何seo推广
  • 网络工程解决方案公司win10优化大师有用吗
  • 赣州网站建设费用网络运营推广
  • b2c商城网站建设已矣seo排名点击软件
  • 务川做网站wguser百度服务电话
  • wordpress安装脚本打不开seo人员招聘
  • c 中怎么用html5做网站百度帐号登录
  • 如何选择医疗网站建设网站seo专员招聘
  • 深圳专业做网站排名哪家好产品关键词
  • php开发网站建设千锋教育培训机构怎么样
  • 金融机构网站建设费用上海百度竞价点击软件
  • 什么是网络营销战略?网络营销战略有哪些基本类型优化设计高中
  • 国外 网站页面设计广告宣传语
  • 苏州制作网站的公司哪家好全网推广平台推荐
  • .net空网站做九九乘法表东莞seo
  • 4399在线观看免费韩国seo查询官网
  • 为什么说做网站赚钱建网站一般需要多少钱
  • 望江县住房和城乡建设局网站中小企业网站
  • 注册公司没有场地怎么办seo工资多少
  • 加快建设公司新版网站长春网站建设方案推广
  • 无锡做网络推广常德网站seo
  • 死循环网站win优化大师怎么样
  • 找外贸工作哪个网站好广告投放是什么工作
  • 网站开发教案软文广告素材
  • 对高校网站建设的期待武汉网站seo
  • flash网站规划微信营销管理软件