-
紫衣仙女
你的要求可以这样理解?我在 beforeCreate 里请求一个API,之后就不希望 VUE 继续,直到数据回来后再执行 VUE 的生命周期?如果是这样的,那办不到。简单的变通方法,可以使用楼上的 v-if 思路。另外,也是官方可以做到的,可以这样。在路由跳转到此之前请求数据,请求到执行 next() 操作后,再开始执行 VUE 的生命周期。资料:在导航完成前获取数据
-
翻翻过去那场雪
渲染之前的话,created,beforeCreate就开始调接口,然后页面刚进来就弄为空,有返回之后再显示相应的部分。这样渲染和请求是异步的,等到请求回来之后再把页面放出来(v-if)。
-
回首忆惘然
ajax是异步操作,vue不能保证在渲染之前拿到数据,vue能做的是初始化页面隐藏(visibility:hidden),拿到数据再显示。
-
哔哔one
楼上正解,由于异步操作的存在,vue是不能保证在页面渲染之前就拿到数据的,所以一般的做法是,隐藏页面,在created或者beforeCreate的时候调用接口获取数据,在成功拿到数据之后的回调函数里面,控制页面显示,这样可以最大程度上避免页面跳动的问题
-
慕村9548890
这种问题的解决思路不是应该加一个loading吗。。。在异步获取数据的时候加上一个loading表示现在在获取数据,然后再获取数据之后再进行重新的渲染
-
慕桂英546537
这种应该用路由的钩子beforeRouterEnter(to,from,next) { doAjax.then(res => { // 获取数据 next(vm => { // 对数据进行操作 }) })}