浏览器什么时候执行 JavaScript?执行游标是如何移动的?

JavaScript 是一种广泛用于 Web 开发的脚本语言,它可以在浏览器端运行。但是,当浏览器加载一个包含 JavaScript 代码的网页时,它究竟是在什么时候开始执行这些代码呢?执行游标又是如何移动的呢?在本文中,我们将探讨这些问题,并提供相关的示例代码和指导意义。

执行时间

当浏览器开始加载一个网页时,它会按照以下顺序执行其中的代码:

  1. 加载 HTML 文件。
  2. 发现 <script> 标签并加载相应的 JavaScript 文件。
  3. 在遇到 deferasync 属性的 <script> 标签时,浏览器会延迟执行 JavaScript 代码,直到文档解析完成后再执行。而如果没有这些属性,则会立即执行代码。
  4. 如果 JavaScript 代码需要与 DOM 元素交互(比如修改元素的样式或内容),则需要等待文档解析完成后再执行。

因此,如果你希望 JavaScript 代码能够在 DOM 解析完成后再执行,你可以使用 defer 属性:

------
  ------
    ----------------------
    ------- ----- --------------------------
  -------
  ------
    ---
  -------
-------

执行流程

当 JavaScript 代码开始执行时,浏览器会创建一个全局执行上下文,并将其压入执行上下文栈。然后,JavaScript 引擎会从全局执行上下文中开始执行代码。在执行过程中,如果遇到函数调用,则会创建一个新的执行上下文,并将其压入执行上下文栈。当函数执行完毕后,其对应的执行上下文会从栈中弹出。

在执行 JavaScript 代码的过程中,引擎会使用一个执行游标(也称为程序计数器)来跟踪当前要执行的代码块。当引擎遇到一个代码块时,它就会将游标移到该代码块的起始位置,并开始执行其中的语句。一旦执行完成,游标就会移到下一个语句或代码块的起始位置。这个过程会一直重复,直到所有的语句都被执行完毕。

以下是一个简单的示例,演示了 JavaScript 代码的执行流程:

-------- ----------- -
  ------------------- - - ---- - -----
-

---------------

在这个例子中,当 greet 函数被调用时,引擎会创建一个新的执行上下文,并将其压入执行上下文栈。然后,引擎会将游标移到 greet 函数体的起始位置,并开始执行其中的语句。在这个例子中,只有一行语句,它会输出一条问候信息。当函数执行完毕后,其对应的执行上下文会从栈中弹出,并将游标移到调用该函数的位置,继续执行后续的代码。

指导意义

了解 JavaScript 代码的执行时间和流程对于编写高效、可靠的代码非常重要。以下是一些指导意义:

  • 如果你需要确保 JavaScript 代码能够在 DOM 解析完成后再执行,可以使用 defer 属性或将代码放在 </body> 标签前。
  • 避免在全局作用域中声明过多的变量和函数,因为这可能会导致名称冲突和性能问题。
  • 尽可能地将变量和函数声明限定在局部作用域内,以减少命名空间

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/14541


猜你喜欢

  • 使用Node.js解析JSON文件

    使用Node.js解析JSON文件 什么是JSON? JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。它基于JavaScript语法,但是与之不同的是,它...

    7 年前
  • 我应该在大括号之后使用分号吗?

    在前端开发中,使用分号(;)是一种很常见的习惯。但是,在大括号({})之后使用分号是否必要呢?本文将会探讨这个问题,并给出一些指导意义和示例代码。 分号的作用 在 JavaScript 中,分号通常被...

    7 年前
  • 根据元素长度排序的前端技巧

    在开发 Web 应用程序时,经常需要对数据进行排序。而有时我们可能需要根据文本元素的长度来排序,例如按单词长度对文章进行排序。在本文中,我们将介绍一种根据元素长度排序的前端技巧,并提供示例代码。

    7 年前
  • 推特 Bootstrap onclick 事件按钮收音机

    Bootstrap 是一个流行的前端框架,它为开发人员提供了简单易用的工具和组件,以帮助构建现代化的网站和应用程序。其中,onclick 事件是在用户点击按钮时触发的常见事件之一。

    7 年前
  • HTML5视频尺寸

    HTML5的出现为网页媒体展示带来了全新的方式,其中最显著的进步之一就是HTML5元素支持本地视频播放。当您想要在网站中添加视频时,不仅需要考虑到视频编码和格式等技术细节,还需要关注视频尺寸的设置。

    7 年前
  • 我如何用JavaScript打印一个渲染HTML页面的一部分?

    在前端开发中,有时候需要将网页上的部分内容以纸质形式输出,这就需要使用 JavaScript 将 HTML 页面转换成可打印的格式。接下来,我将详细介绍如何使用 JavaScript 打印一个已经渲染...

    7 年前
  • 使用Ajax请求下载文件

    在前端开发中,有时需要通过Ajax请求从服务器下载文件。本文将介绍如何使用Ajax实现文件下载功能,包含详细的代码示例和深入探讨。 为什么需要使用Ajax请求下载文件? 传统的文件下载方式是通过链接直...

    7 年前
  • 让 React 组件/DIV 拖动的推荐方式

    在现代 Web 应用程序中,拖放功能已经成为了一个非常常见的功能。React 是一个流行的 Javascript 库,提供了一系列工具和 API 来方便地实现这一功能。

    7 年前
  • 替换字符串中的所有事件[副本]

    在前端开发中,处理字符串是非常常见的任务之一。其中一个很常见的需求是替换字符串中的某些内容,这可能包括整个单词、部分单词、甚至是特殊字符。 在本文中,我们将探讨如何使用 JavaScript 来替换字...

    7 年前
  • 使用什么来最小化和压缩JavaScript库?

    在前端开发中,JavaScript 库是必不可少的。但是,这些库往往会非常大,给网页加载速度带来不必要的负担。为了解决这个问题,我们可以使用一些工具来最小化和压缩 JavaScript 库。

    7 年前
  • 如何设置HTML5音频位置

    在现代Web开发中,音频是一个重要的元素。HTML5音频元素使得在网站上嵌入音频变得更加容易。但是,如果您想让音频播放器出现在页面的特定位置,它可能需要一些额外的工作。

    7 年前
  • 在jqGrid中隐藏列

    在前端开发中,我们常常需要使用jqGrid来展示数据。jqGrid是一个基于jQuery的表格插件,它支持各种功能,如排序、分页和搜索等。 有些时候,我们希望在jqGrid中显示的数据不包含某些列,或...

    7 年前
  • JavaScript中的关联数组与对象

    在JavaScript中,可以使用对象来表示键值对的集合。这些键值对可以通过点和方括号访问方式进行访问。在JavaScript中,关联数组和对象是相似的概念。 对象 对象是JavaScript中最基本...

    7 年前
  • 用 jQuery 发送 JSON 数据

    在前端开发中,与后端进行数据交互是必不可少的环节。其中一种常见的方式是通过发送 JSON 数据来实现。而使用 jQuery 可以大大简化这个过程。 准备工作 在开始之前,需要确保已经引入了 jQuer...

    7 年前
  • 在contenteditable插入符号插入HTML div

    简介 contenteditable 属性是 HTML5 中新增的属性,它允许用户可以编辑网页中的内容。当 contenteditable 属性设置为 true 时,元素将变成可编辑的状态。

    7 年前
  • 赋值左侧的 JavaScript 对象括号表示法({导航})

    在 JavaScript 中,对象是一种非常重要的数据类型。对象可以定义为具有属性和方法的集合。通常情况下,我们使用点表示法来访问和设置对象属性的值。但是,在某些情况下,我们可能需要使用另一种方式来访...

    7 年前
  • 用 JavaScript 截断(不舍入)十进制数

    在前端开发中,我们常常需要对数字进行处理。有时候,我们不想将一个浮点数舍入成整数或保留特定的小数位数,而是需要截断十进制数到指定的位数。本文将介绍如何使用 JavaScript 来实现这一功能。

    7 年前
  • 如何重载/刷新的jQuery DataTable?

    jQuery DataTable 是一个流行的前端库,用于在 HTML 表格中添加高级交互和排序功能。有时,在表格数据发生更改后,需要动态地重载或刷新 DataTable 以更新显示的数据。

    7 年前
  • 如何在指定的 div 中添加目标="_blank" 的链接

    在前端开发中,我们常常需要在网页中添加链接。有些情况下,我们希望当用户点击链接时,在新的浏览器选项卡中打开链接。为了实现这个功能,我们可以使用 target="_blank" 属性。

    7 年前
  • 使用Require.js时遇到模块加载超时错误的解决方案

    在使用Require.js构建前端项目时,偶尔会遇到模块加载超时的错误。这个错误通常出现在加载大型依赖库或者网络不佳的情况下,如骨干(Backbone)、jQuery Mobile等。

    7 年前

相关推荐

    暂无文章