【JavaScript】浏览器与事件循环

浏览器的进程模型

主要包含:浏览器进程、网络进程、渲染进程;

一个进程就是一块内存空间;

进程:操作系统资源分配的基本单位,每一个进程都拥有独立的内存空间和系统资源,可以独立运行;

线程:操作系统任务调度和执行的基本单位;

渲染进程

1、会启动一个渲染主线程(执行js、渲染页面),处理html、css、js

2、主要线程:其中js、渲染线程是只能进行一个;

  • JS引擎线程(在主线程中,执行JS代码)
  • GUI渲染线程(在主线程中,解析HTML,CSS,构建DOM树和RenderObject树,布局和绘制等)
  • 事件触发线程(控制事件循环,当事件被触发,将异步任务或者某些触发事件如:click等放入事件队列中,等待JS引擎执行)
  • 定时器线程(处理settimeout和settimeinterval)
  • 异步HTTP请求线程(负责发起http网络请求,当请求完成后将事件放入事件队列中,等待JS引擎执行)

3、无限循环(又叫消息循环、事件循环)去消息队列(message queue)中拿任务(js代码);没有任务会休眠;执行 JS 时遇到其他线程可以做的事(如定时器、网络请求、监听事件、修改页面等),调用其他线程执行,其中异步线程的执行异步任务并在执行完结束后将回调添加到消息队列尾部,属于渲染线程的就直接放到队列中,等待主线程把当前同步任务执行完去循环队列,若此时主线程休眠,则唤醒渲染主线程进行循环;

4、优先级

任务没有优先级按先后顺序,队列有优先级,同一类型的任务放在相同的队列,如谷歌有延时队列、交互队列、微队列等,浏览器循环时可以从不同队列中获取任务,其中微队列优先级最高;

相关推荐
木易 士心1 小时前
ESLint 全指南:从原理到实践,构建高质量的 JavaScript/TypeScript 代码
javascript·ubuntu·typescript
前端达人1 小时前
都2026年了,还在用Options API?Vue组合式API才是你该掌握的“正确姿势“
前端·javascript·vue.js·前端框架·ecmascript
chao-Cyril2 小时前
从入门到进阶:前端开发的成长之路与实战感悟
前端·javascript·vue.js
前端达人3 小时前
被JavaScript忽视的Web Animations API:为什么说它是前端动画的真正未来?
开发语言·前端·javascript·ecmascript
2301_796512524 小时前
【精通篇】打造React Native鸿蒙跨平台开发高级复合组件库开发系列:Swipe 轮播(用于循环播放一组图片或内容)
javascript·react native·react.js·ecmascript·harmonyos
念念不忘 必有回响4 小时前
前端判断文本是否溢出:单行与多行场景的完整解析
前端·javascript·css·vue.js
css趣多多4 小时前
vue3的组件间通信ref子组件需要把父组件要的ref数据开放
前端·javascript·vue.js
我是伪码农5 小时前
Vue 2.10
前端·javascript·vue.js
AAA阿giao5 小时前
React 性能优化双子星:深入、全面解析 useMemo 与 useCallback
前端·javascript·react.js
shadowingszy5 小时前
【前端趋势调查系列】带你看看前端生态圈的技术趋势state-of-js 2025详细解读
前端·javascript·vue.js