AsyncData在组件结构中,其属于宿主layout下的子组件,不属于页面组件,无法使用页面组件中的fetch方法,官方的解释是子组件无法使用阻塞异步请求,即:子组件得到的异步数据无法用于服务端渲染,这对于程序是合理的,避免异常阻塞,简化业务模型。

如果需要这些异步数据增强站内内链SEO,我们可以巧妙地使用内置vuex中的nuxtServerInit这个API,这个API实在nuxt程序实例化之后第一次执行的方法,其内部返回一个promise,我们可以在这里完成我们站内的所有子组件异步请求,随后将数据映射至对应子组件即可。

另外的方法是在mounted 方法去调用异步数据。

注:在这个data方法里面,我们获取不到 this指针,因为data方法在组件初始化之前就已经被调用了。

摘录: https://zhuanlan.zhihu.com/p/27703851
Logo

前往低代码交流专区

更多推荐