推荐在 mounted
生命周期钩子中发起请求。这样做有几个重要的理由:
-
确保 DOM 已经被渲染:
mounted
钩子在组件的 DOM 已经被插入文档之后调用。这意味着你可以确保所有的 DOM 元素都已经存在,如果你的请求结果需要直接操作或依赖这些 DOM 元素,那么在mounted
中发起请求是安全的。
-
避免不必要的请求:
- 在
created
钩子中发起请求有时会导致在组件还没有挂载时请求数据。如果组件在请求完成之前被销毁,可能会引发内存泄漏或不必要的资源浪费。因此,等待组件挂载完成再发起请求可以减少这些潜在问题。
- 在
-
处理组件状态:
- 在
mounted
钩子中发起请求,能够确保你有机会在请求开始前处理组件的状态(例如设置加载状态),并且在请求完成后更新组件的状态(例如显示数据或处理错误)。
- 在
尽管 mounted
是推荐的生命周期钩子,但也有一些特定场景可能需要在 created
钩子中发起请求,例如:
- SSR(服务器端渲染):在服务器端渲染中,Vue 实例的
mounted
钩子不会被调用,因为 DOM 并不会被真正挂载。在这种情况下,你可能需要在created
钩子中发起请求。 - 依赖数据初始化:如果组件在挂载之前就需要某些数据来初始化,可以在
created
钩子中发起请求,以确保数据在组件挂载时已经可用。
代码示例
export default {
data() {
return {
items: [],
loading: false,
error: null,
};
},
mounted() {
this.fetchData();
},
methods: {
async fetchData() {
this.loading = true;
try {
const response = await axios.get("/api/items");
this.items = response.data;
} catch (error) {
this.error = error;
} finally {
this.loading = false;
}
},
},
};