关于网页图片延迟加载的问题

JavaScript025

关于网页图片延迟加载的问题,第1张

您好:您看插件的名字应该知道,是滚动条动的时候才会延时加载。所以scrollLoading中肯定加了滚动条事件,在滚动事件中加的加载的方法。这样就只能改动他的js插件才可以了。找到加滚动事件的方法。看他里面怎么实现滚动加载的,然后把加到你的图片滚动事件中就可以了。目测只有这一个方法。

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

一、同步加载

平常默认用的都是同步加载。如:<script src="http://y.com/script.js"></script>

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

二、异步加载

(function() {

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)

})()

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

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

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

三、延迟加载(lazy loading)

前面解决了异步加载(async loading)问题,再谈谈什么是延迟加载。

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

也就是将 js 切分成许多模块,页面初始化时只加载需要立即执行的 js ,然后其它 js 的加载延迟到第一次需要用到的时候再加载。

特别是页面有大量不同的模块组成,很多可能暂时不用或根本就没用到。

就像图片的延迟加载,在图片出现在可视区域内时(在滚动条下拉)才加载显示图片

四、预加载

预加载是一种浏览器机制,使用浏览器空闲时间来预先下载/加载用户接下来很可能会浏览的页面/资源,当用户访问某个预加载的链接时,如果从缓存命中,页面就得以快速呈现。