项目背景
在主文件index.vue中初始化页面相关的操作,
在mounted中放置用户权限判断并更新store中的权限值,当点击相应组件时mounted可正常工作,
但是在用户手动刷新时mounted内的函数并未执行,导致相应组件未获取到权限而显示异常
问题解决
首先,这跟vue生命周期有关,图就不贴了,直接说原因。
当用户f5刷新页面时,整个页面会重新去请求,js的状态变量消失,但是el节点并未重新建立。
因为,mounted是el被新创建的vm.$el替换,并挂载到实例上去之后调用的钩子,此处el并未重新挂载,故该钩子函数不会被调用。
此处可以将用户权限判断的方法根据实际情况写在beforeMount或created中
常见的钩子触发事件
beforeCreate
在实例初始化之后,数据观测(data observer) 和 event/watcher 事件配置之前被调用。数据和实例都不能访问
created
实例已经创建完成之后被调用。在这一步,实例已完成以下的配置:数据观测(data observer),属性和方法的运算, watch/event 事件回调。然而,挂载阶段还没开始,$el 属性目前不可见。
数据可以访问,实例不可访问
beforeMount
在挂载开始之前被调用:相关的 render 函数首次被调用。
DOM挂载前,数据可访问,实例$el为虚拟DOM节点,不可访问,数据还未插入DOM中
<