js延迟加载的方式有哪些?
一般有以下几种方式:
成都一家集口碑和实力的网站建设服务商,拥有专业的企业建站团队和靠谱的建站技术,十多年企业及个人网站建设经验 ,为成都上千客户提供网页设计制作,网站开发,企业网站制作建设等服务,包括成都营销型网站建设,品牌网站设计,同时也为不同行业的客户提供网站设计、网站建设的服务,包括成都电商型网站制作建设,装修行业网站制作建设,传统机械行业网站建设,传统农业行业网站制作建设。在成都做网站,选网站制作建设服务商就选创新互联。
defer 属性
HTML 4.01 为 script标签定义了 defer属性。
用途:表明脚本在执行时不会影响页面的构造。也就是说,脚本会被延迟到整个页面都解析完毕之后再执行。
在script 元素中设置 defer 属性,等于告诉浏览器立即下载,但延迟执行。
!DOCTYPE htmlhtmlheadscript src="test1.js" defer="defer"/scriptscript src="test2.js" defer="defer"/script/headbody !-- 这里放内容 -- /body/html
说明:虽然script 元素放在了head元素中,但包含的脚本将延迟浏览器遇到/html标签后再执行。
HTML5规范要求脚本按照它们出现的先后顺序执行。在现实当中,延迟脚本并不一定会按照顺序执行。
defer属性只适用于外部脚本文件。支持 HTML5 的实现会忽略嵌入脚本设置的 defer属性。
2. async 属性
HTML5 为 script标签定义了 async属性。与defer属性类似,都用于改变处理脚本的行为。同样,只适用于外部脚本文件。
目的:不让页面等待脚本下载和执行,从而异步加载页面其他内容。
异步脚本一定会在页面 load 事件前执行。
不能保证脚本会按顺序执行。
!DOCTYPE htmlhtmlhead script src="test1.js" async/scriptscript src="test2.js" async/script /headbody !-- 这里放内容 -- /body/html
4.使用jQuery的getScript()方法
$.getScript("outer.js",function(){//回调函数,成功获取文件后执行的函数
console.log("脚本加载完成")
});
5.使用setTimeout延迟方法
6.让JS最后加载
把js外部引入的文件放到页面底部,来让js最后引入,从而加快页面加载速度
by三人行慕课
利用JQuery.LazyLoad实现图片延迟加载,求大神指教。。。
云联中国可以负责任的告诉你,你给的财富值太少了!
1.不用说了,肯定是导入JS插件
script src=”jquery.js” type=”text/javascript”/script
script src=”jquery.lazyload.js” type=”text/javascript”/script
在你的页面中加入如下的javascript:
script type=”text/javascript” charset=”utf-8″
$(function() {
$(“img.lazy”).lazyload();
});
/script
2.如果想提载入图片,可以使用 threshold 进行设置,下例的含义是:在图片距离屏幕180px时提前载入
$(“img.lazy”).lazyload({ threshold :180});
可以自定义一个简单的浅色或灰色系的小图片(越小越好,1*1px最佳,格式推荐采用gif)作为占位图片来触发加载动作。
事件触发可以是jQuery的任何事件(如click、mouseover),还可以使用自己定义的事件。
例如:处于等待状态, 直到浏览者滚动到窗口中图片所在位置,在占位图片被点击之前不加载图片, 可以这样做:
$(“img”).lazyload({
placeholder : “img/grey.gif”,
event : “click”
});
3.当图片完全加载的时候,默认使用show()方法来显示图片,所以,上面的那个基本设置示例中未写出show(),但是可以照常运行。
图片淡入(FadeIn)效果$(“img.lazy”).lazyload({
effect : “fadeIn”
});
Lazyload图片淡入效果演示
将图片放在特定容器中
先看示例:水平滚动演示页面和垂直滚动的演示页面
CSS部分示例
#container {
height: 600px;
overflow: scroll;
}
js部分示例
$(“img.lazy”).lazyload({
container: $(“#container”)
});
图片未按顺序排列的情况
滚动页面的时候,Lazyload会按照在HTML代码中的顺序先后可视范围内的加载图片,在第一张不在可视范围内的图片处停止执行,但是在某些页面布局中,这种聪明的假设可能是不成立的,那么可以用failurelimit来控制加载动作:
$(“img.lazy”).lazyload({
failure_limit : 10
});
上面的意思是:在找到10张不在可视范围内的图片时停止执行。额,好吧,如果你的页面布局猥琐到10不足以满足的时候,那就再大一些吧。
Lazyload定时延迟图片载入
Lazyload的一个并不完备的功能,并不影响使用,但是实际用途并不大!用途描述:在页面和可见图片载入后一定时间内载入图片。Lazyload定时延迟图片载入示例
$(function() {
$(“img:below-the-fold”).lazyload({
event : “sporty”
});
});
$(window).bind(“load”, function() {
var timeout = setTimeout(function() {$(“img.lazy”).trigger(“sporty”)}, 5000);
});
上例中采用的参数或者说定时是5秒。
加载隐藏的图片
你的页面上可能隐藏了很多不可见的图片用作特殊用途,Lazyload默认是忽略这些图片的,如果不想忽略掉,可以这样:
$(“img.lazy”).lazyload({
skip_invisible : false
});
你看到这篇文章时可能有更新的版本了,请百度搜索Lazyload了解更多!如果这则经验通过了,希望大家能够为我补充一下不足之处!谢谢。
兼容于:OSX平台: Safari 5.1, Safari 6, Chrome 20, Firefox 12
WIN平台:Chrome 20, IE 8 and IE 9 on Windows
iPhone和 iPad上:Safari 5.1
jquery图片调用延迟加载最佳代码怎么写?
jquery是在html文档加载完才执行的,如果网页上图片过多,没有下载完的话是无法加载效果的。
jquery延迟加载遇到不间断的滚动图片条后,后面的图片就不显示的,怎么解决?
延迟加载一般是根据当前滚动条的位置来决定何时加载图片。
所以个人觉得,在做图片延迟加载时,不建议直接对img直接筛选
针对主要内容区域进行延迟加载就可以了。
例如 $("#Containter img").lazyload()
这样做的目的就是合理避开你需要滚动的地方
用jquery怎么延时加载ajax?
$(document).ready(function() {
$(".mainbox").hover(function() {
t = setTimeout(function() {
//这里写你的AJAX请求
}, 3000);
},function() {
clearTimeout(t);
});
});
javascript或jquery如何实现延迟加载js文件
1、把js的代码放在body里面,最好是放在页面最后的位置,而不是放在head里面。这样整个页面加载结束的时候才会加载到js。
2、你可以使用js函数动态的修改页面,加载js。下面附上两个函数,可以用来加载js或者css。
/*Title : 包含其它 js 文件。
* Description : 将其它 Js 文件引入本文件中,方便管理、维护。*/
function include_js(path) {
var sobj = document.createElement('script');
sobj.type = "text/javascript";
sobj.src = path;
var headobj = document.getElementsByTagName('head')[0];
headobj.appendChild(sobj);
}
/* Title : 包含其它 css 文件。
* Description : 将其它 css 文件引入本文件中,方便管理、维护。 */
function include_css(path) {
var fileref = document.createElement("link")
fileref.rel = "stylesheet";
fileref.type = "text/css";
fileref.href = path;
}
3、利用ajax加载js。
分享题目:jquery的延迟加载,jquery动画延迟方法
本文地址:http://scpingwu.com/article/hoidjj.html