在 Vue 中,created 和 mounted 是两个生命周期钩子,它们之间的调用时差主要受以下几个因素影响:
🟢 1. 模板复杂度与渲染耗时(最主要因素)
mounted 的触发时间是在组件的 DOM 被挂载之后(也就是插入到真实 DOM 中之后),而 created 是在组件实例创建完成、数据已设置好但 DOM 还未生成前执行。
因此,如果组件模板(template)结构复杂,或者包含大量的动态绑定、指令、v-for、组件嵌套等操作,DOM 渲染和挂载过程就会变慢,从而延长 created → mounted 之间的时间间隔。
🟢 2. 异步依赖资源加载(图片、子组件等)
虽然 Vue 是异步渲染 DOM 的,但如果组件中引用了大量需要异步加载的内容,如图片、异步组件、懒加载模块等,也可能造成渲染阻塞,影响 mounted 的触发时间。
🟢 3. 浏览器性能和主线程阻塞
如果页面同时进行大量 JavaScript 运算或 DOM 操作(比如同时渲染多个大型组件),也会影响 Vue 的渲染调度,从而推迟 mounted 的触发。
🟢 4. 父组件是否控制了显示节奏(如 v-if)
如果父组件通过 v-if 控制子组件是否挂载,那么即使子组件已经走过 created,只有在 v-if 为 true 后才会走 mounted。这种场景下,created 和 mounted 间的时间差可能非常大,甚至是“人为控制”的。
🟢 5. 使用 keep-alive 或缓存机制
当组件被缓存(keep-alive)时,再次激活并不会重新走 mounted,而是走 activated 钩子,这可能影响你观察 mounted 的时间差。
🟡 补充:如何测量 created 和 mounted 时间差?
可以使用如下方式:
export default {
created() {
this._start = performance.now();
},
mounted() {
const duration = performance.now() - this._start;
console.log(created → mounted 耗时:${duration.toFixed(2)}ms);
}
}
🧠 总结:
影响 created 和 mounted 之间调用时差的关键是:DOM 渲染与挂载所需时间。而这个时间主要取决于模板复杂度、异步资源加载、浏览器性能和父组件控制逻辑等。