今天,几乎没有一家电子商务网站不用 JavaScript,因为诸如将商品放入购物车、订购过程等过程通常都需要调用JavaScript 功能。
什么是 JavaScript
JavaScript是一种轻量级的解释型编程语言,用于创建交互式网页和Web应用程序。
主要有以下几种JavaScript:
- 原生JavaScript:是JavaScript的核心,用于浏览器端编程,可以实现网页特效和交互功能。
- Node.js:用于服务器端编程,可以构建高性能Web应用。
- TypeScript:JavaScript的超集,增加了可选的静态类型检查,使大型项目的JavaScript开发更容易。
- React:Facebook开发的JavaScript库,用于构建用户界面和Web应用。
- Angular:Google推出的用于开发单页Web应用的框架。
- Vue.js:一套用于构建用户界面的渐进式框架。
JavaScript的主要功能包括:
- 操作DOM,控制页面元素内容、样式、动画等。
- 处理浏览器事件,实现交互功能。
- 通过Ajax与服务器进行异步通信,实现动态更新页面。
- 在客户端存储数据,如使用cookie或localStorage。
- 现代JavaScript框架可用于构建复杂的单页Web应用。
JavaScript 有诸多优点,譬如允许在网页上实现一定的视觉效果,与访问者进行交互来提升用户体验。然而,应用 JavaScript时 ,用户浏览器需加载、解释和执行代码。这就产生JS的最大问题,它使网站变慢。Google 的 Alan Kent 解释了如何确保网站在使用 JavaScript 时,不至于太慢的一些绩效。
1,避免 JavaScript 文件的扩散
JavaScript 文件往往会随着时间的推移而不断增加,如向网页添加新功能。由于必须单独请求和加载每个文件,这可能会减慢受影响的页面。为避免这种情况,您可以将较小的 JavaScript 文件合并到较大的文件中,并行加载会减少加载时间。
有几种工具可以合并 JavaScript 文件,如webpack。如果一个网站支持HTTP/2,这可以进一步提高加载效率。
2,减少DNS解析次数
如果须从许多不同的域加载 JavaScript 文件,则需要相应数量的 DNS 查找解析,这都需要时间。为了加快速度,您可以尝试在自己的服务器上托管一些 JavaScript 文件。
一些在其他网站上也使用的流行 JavaScript 文件可能已经在访问者的浏览器缓存中。
3,去除低效的JavaScript
给客户端 CPU 带来沉重负担的 JavaScript,在执行时阻塞页面渲染的 JavaScript,甚至使用文档.write是低效 JavaScript 的例子。Google PageSpeed Insights 识别出低效的 JavaScript 并将其显示在测试结果中。
这些问题的一种解决方案是编写更好的 JavaScript 代码或在网站上使用更好的 JavaScript 库。但这可能会变得非常复杂,必须根据具体情况进行评估。
4,去除不必要的JavaScript
大多数网站不会使用特定 JavaScript 库中提供的所有功能。使用完整的库会导致不必要的加载时间,因为必须传输、解释和执行文件。
Google Page Speed Insights 还会显示关于 JavaScript 的非必需信息。但是,执行 JavaScript 可能取决于上下文,例如,A/B 测试需要 JavaScript 的不同部分。因此,在删除看似不必要的代码时应小心。
5,压缩 JavaScript 文件
即使解压缩传输的压缩 JavaScript 文件会导致客户端上的 CPU 负载更高,这种技术通常也会导致加载时间的整体加速。这也是因为 JavaScript 文件可以很好地压缩,节省的传输数据量很大。
6,注意高效缓存
浏览器也可以通过在 HTTP 标头中正确指定文件的会话周期来减轻负担,例如使用“缓存控制”并设置足够长的时间直到文件过期。
但是,必须注意在必要时可以更新文件。这可以通过将版本号或文件内容的哈希添加到 URL 来实现。此外,将众所周知的 JavaScript 文件引用到共享服务器可以允许浏览器使用文件的缓存版本。
结语
JavaScript 在许多网站上都是有用且不可或缺的。为了在使用 JavaScript 的情况下将加载时间保持在限制范围内,应应用各种最佳实践。其中一些如启用缓存或压缩文件传输,更容易实现。其他的如提高代码的效率,可能需要大量的工作,具体取决于具体情况。在每种情况下,都必须在努力和收益之间进行有意义的比较。