zoukankan      html  css  js  c++  java
  • 如何正确的加载和执行 JavaScript 代码

          无论当前 JavaScript 代码是内嵌还是在外链文件中,页面的下载和渲染都必须停下来等待脚本执行完成。JavaScript 执行过程耗时越久,浏览器等待响应用户输入的时间就越长。浏览器在下载和执行脚本时出现阻塞的原因在于,脚本可能会改变页面或 JavaScript 的命名空间,它们对后面页面内容造成影响。

    在 <head> 中加载外链的 JavaScript的缺点:,当浏览器解析到 <script> 标签时,浏览器会停止解析其后的内容,而优先下载脚本文件,并执行其中的代码,这意味着,其后的 styles.css 样式文件和<body>标签都无法被加载,由于<body>标签无法被加载,那么页面自然就无法渲染了。因此在该 JavaScript 代码完全执行完之前,页面都是一片空白。

    推荐的代码放置位置:将脚本放在底部,这也是优化 JavaScript 的首要规则。

    减少 JavaScript 对性能的影响有以下几种方法:

    • 将所有的<script>标签放到页面底部,也就是</body>闭合标签之前,这能确保在脚本执行前页面已经完成了渲染。
    • 尽可能地合并脚本。页面中的<script>标签越少,加载也就越快,响应也越迅速。无论是外链脚本还是内嵌脚本都是如此。
    • 采用无阻塞下载 JavaScript 脚本的方法:
      • 使用<script>标签的 defer 属性(仅适用于 IE 和 Firefox 3.5 以上版本);
      • 使用动态创建的<script>元素来下载并执行代码;
      • 使用 XHR 对象下载 JavaScript 代码并注入页面中。

    具体方法及示例见http://www.ibm.com/developerworks/cn/web/1308_caiys_jsload/index.html

  • 相关阅读:
    centos7/RHEL7安装LibreOffice
    CentOS7开机启动管理systemd简介及使用
    Vim使用技巧
    16_用LVM扩展xfs文件系统(当分区空间不够时)
    15_RHEL7挂载NTFS分区
    14_RHEL7安装mplayer
    polyfill-eventsource added missing EventSource to window ie浏览器 解决方案
    关于vue,webpack 中 “exports is not defined”报错
    2018 vue前端面试题
    Error: No PostCSS Config found in... 报错 踩坑记
  • 原文地址:https://www.cnblogs.com/houxiaohang/p/4602456.html
Copyright © 2011-2022 走看看