介绍同步加载、异步加载、延迟加载

同步加载 同步模式又称阻塞模式,会阻止浏览器的后续处理,停止了后续的文件的解析,执行,如图像的渲染。流览器之所以会采用同步模式,是因为加载的js文件中有对dom的操作,重定向,输出document等默认行为,所以同步才是最安全的。通常会把要加载的js放到body结束标签之前,使得js可在页面最后加载,尽量减少阻塞页面的渲染。这样可以先让页面显示出来

简单的说

js在网页中加载会阻塞到未加载的css,html的加载跟渲染

•异步加载也叫非阻塞模式加载,浏览器在下载js的同时,同时还会执行后续的页面处理。

在script标签内,用js创建一个script元素并插入到document中,这种就是异步加载js文件了。

•同步加载流程是瀑布模型,异步加载流程是并发模型。

简单的说

•异步加载不会阻塞未加载的css、html的加载,

延迟加载(lazy loading)

延迟加载:有些 js 代码并不是页面初始化的时候就立刻需要的,而稍后的某些情况才需要的。延迟加载就是一开始并不加载这些暂时不用的js,而是在需要的时候或稍后再通过js 的控制来异步加载。

简单的说

•用的时候再执行,不用不执行

分享下封装好的代码

 function loadScript() {
   var script = document.createElement("script");
   script.type = "text/javascript";
 //<script style = “text/javascript”>
   script.src = url;
 //<script style = “text/javascript” url = “”>
   if(script.readyState) {}
// readyState载入中
   (function() {
   function async_load() {
   var s = document.createElement(‘script‘);
   s.type = ‘text/javascript‘;
   s.async = true;
   s.src = ‘http://yourdomain.com/script.js‘;
   var x = document.getElementsByTagName(‘script‘)[0];
   x.parentNode.insertBefore(s, x);
// parentNode返回元素的父节点
 // insertBefore在当前子节点的旁边插入节点
   }
   if(window.attachEvent)
 //attachEvent将代码层跟ul层相分离
  window.attachEvent(‘onload‘, async_load);
   else
  window.addEventListener(‘load‘, async_load, false);
   })(); 

原文地址:https://www.cnblogs.com/Tmode/p/10942093.html

时间: 2024-10-11 05:47:18

介绍同步加载、异步加载、延迟加载的相关文章

【转】【玩转cocos2d-x之二十三】多线程和同步03-图片异步加载

原创作品,转载请标明:http://blog.csdn.net/jackystudio/article/details/15334159 cocos2d-x中和Android,Windows都 一样,如果在主线程中处理一些耗时操作,那么主线程就会出现阻塞现象,表现在界面上就是卡住,未响应等情况.为了避免这种情况的出现,我们需要在后台开辟 工作线程进行数据的处理,再采用消息传递或者其他形式来通知主线程进行UI变化.最常见的情况就是游戏进入前的loading. 1.图片的异步加载 在多线程和同步的第

JS异步加载的几种方式

一:同步加载 我们平时使用的最多的一种方式. <script src="http://yourdomain.com/script.js"></script> <script src="http://yourdomain.com/script.js"></script> 同步模式,又称阻塞模式,会阻止浏览器的后续处理,停止后续的解析,只有当当前加载完成,才能进行下一步操作.所以默认同步执行才是安全的.但这样如果js中有输

js的异步加载及promise的三种状态

---恢复内容开始--- js异步加载 同步加载 <script src="http://baidu.com/script.js"></script>  --->  我们平时经常使用的就是这种同步加载的形式 同步模式,又称阻塞模式,会阻止浏览器的后续处理,停止了后续的解析,因此停止了后续的文件加载(如图像).渲染.代码执行. js 之所以要同步执行,是因为 js 中可能有输出 document 内容.修改dom.重定向等行为,所以默认同步执行才是安全的.

前端性能优化-异步加载

异步加载的方式1:动态脚本加载 异步加载方式2:defer HTML 4 为script标签定义了一个扩展属性:defer. defer是在HTML解析完成之后就会执行,如果有多个,按照加载的顺序依次执行 Defer 属性指明本元素所含的脚本不会修改 DOM,因此代码能安全地延迟执行.defer 属性只被 IE 4 和 Firefox 3.5 更高版本的浏览器所支持,所以它不是一个理想的跨浏览器解决方案.在其他浏览器中,defer 属性会被直接忽略,因此script标签会以默认的方式处理,也就是

点评js异步加载的4种方式

主要介绍了点评js异步加载的4种方式,帮助大家更全面的了解js异步加载方式,感兴趣的小伙伴们可以参考一下 js异步加载的4种方式,点评开始. <!DOCTYPE html> <html> <head> <script src="http://common.cnblogs.com/script/jquery.js" type="text/javascript"></script> <script typ

【EasyUI学习-2】Easyui Tree的异步加载

作者:ssslinppp       1. 摘要 easyui相关的介绍可以上其官网或者百度去搜索,这里不做介绍. Easyui Tree的使用,官网或者easyui中文网站,也有相关介绍,但是官方提供的实例所使用的json是写死的,不是后台实时读取的.在实际的项目中,要显示的tree数据,一般都是从数据库中读取,然后通过通过ajax或者其他技术将tree的json数据发送到前台,然后显示. 本文将介绍easyui tree的异步加载,以及手动展开tree. 2. tree的相关介绍 上图是一个

Unity中场景异步加载

引入命名空间 using UnityEngine.UI; using UnityEngine.SceneManagement; using System.Collections; using System.Collections.Generic; using UnityEngine; using UnityEngine.UI; //引入命名空间 using UnityEngine.SceneManagement;//引入命名空间 public class S2Manager : MonoBeha

AssetBundle异步加载被中断的问题

刘 刘泰言创建于 1 年前 在使用异步接口 yield return AssetBundle.ASyncLoad的时候,难免会想到:这个异步处理完之前如何Cancel掉这个任务?也就是一个AssetBundle加载到一半,现在要放弃加载,应该怎么处理? UnityAssetBundle 赞同 0评论 分享 10条回复 曾 曾毅回答于 1 年前 无法CANCEL 赞同 1评论 分享 Walker回答于 1 年前 Unity的接口里没有中断操作,但是可以在自己项目的ABMgr模块给业务逻辑层提供一个

同步加载、异步加载、延迟加载

一.同步加载 平常默认用的都是同步加载.如:<script src="http://yourdomain.com/script.js"></script>  同步模式又称阻塞模式,会阻止浏览器的后续处理,停止了后续的文件的解析,执行,如图像的渲染.流览器之所以会采用同步模式,是因为加载的js文件中有对dom的操作,重定向,输出document等默认行为,所以同步才是最安全的.通常会把要加载的js放到body结束标签之前,使得js可在页面最后加载,尽量减少阻塞页面