asm.js 的异步脚本

上次我在游戏开发的博客提到了asm.js 的异步脚本,意思就是每个中型或大型游戏都应编译asm.js (en-US)代码作为异步脚本的一部分,以便浏览器能够最大限度地灵活地优化编译过程。在 Gecko 中,异步编译允许 JavaScript 引擎在游戏加载时缓存主线程的 asm.js,并缓存生成的机器代码,这样游戏就不需要在随后的加载中编译(从 Firefox 28 开始)。要查看差异,请切换javascript.options.parallel_parsing in about:config.

异步执行

获取异步编译非常简单:编写 JavaScript 时,只需使用 async 属性即可:

javascript 复制代码
<script async src="file.js"></script>

或者,通过脚本来做同样的事情:

javascript 复制代码
const script = document.createElement("script");
script.src = "file.js";
document.body.appendChild(script);

(从脚本中创建的脚本默认为异步。)默认的 HTML shell Emscripten 生成后者。

什么时候用 async 或者不用?

两种常见的情况下是脚本是 异步的(由HTML 规范定义)

javascript 复制代码
<script async>code();</script>

以及

javascript 复制代码
const script = document.createElement("script");
script.textContent = "code()";
document.body.appendChild(script);

两者都被视为"内联"脚本,阻塞其余所有任务,进行编译,编译完成后立即执行。

如果你的代码是一个 JS 字符串呢?你应该使用带有对象 URL(object URL)的 Blob 对象,而不是使用 evalinnerHTML,这两者都会触发同步编译:

javascript 复制代码
const blob = new Blob([codeString]);
const script = document.createElement("script");
const url = URL.createObjectURL(blob);
script.onload = script.onerror = () => URL.revokeObjectURL(url);
script.src = url;
document.body.appendChild(script);

使用src而不是innerHTML,则该脚本是异步的。

相关推荐
masa0103 分钟前
JavaScript--JavaScript基础
开发语言·javascript
拓端研究室TRL6 分钟前
Python用TOPSIS熵权法重构粮食系统及期刊指标权重多属性决策MCDM研究|附数据代码...
开发语言·python·重构
一只特立独行的猪6111 小时前
Java面试——集合篇
java·开发语言·面试
大得3692 小时前
go注册中心Eureka,注册到线上和线下,都可以访问
开发语言·eureka·golang
小珑也要变强3 小时前
队列基础概念
c语言·开发语言·数据结构·物联网
AI原吾6 小时前
掌握Python-uinput:打造你的输入设备控制大师
开发语言·python·apython-uinput
机器视觉知识推荐、就业指导6 小时前
Qt/C++事件过滤器与控件响应重写的使用、场景的不同
开发语言·数据库·c++·qt
毕设木哥6 小时前
25届计算机专业毕设选题推荐-基于python的二手电子设备交易平台【源码+文档+讲解】
开发语言·python·计算机·django·毕业设计·课程设计·毕设
珞瑜·6 小时前
Matlab R2024B软件安装教程
开发语言·matlab
weixin_455446176 小时前
Python学习的主要知识框架
开发语言·python·学习