当前位置: 首页 > news >正文

西城顺德网站建设新东方

西城顺德网站建设,新东方,网站个人备案模版,华东民航机场建设公司网站一、Lazyload的理解分析 Lazyload技术是一种延迟加载技术,让页面加载速度快到飞起、减轻服务器压力、节约流量、提升用户体验 实现思路 1)页面较长,屏幕的可视区域有限 2)不设置页面中img标签的src属性值或者将其指向同一个占位图…

一、Lazyload的理解分析

  1. Lazyload技术是一种延迟加载技术,让页面加载速度快到飞起、减轻服务器压力、节约流量、提升用户体验

  2. 实现思路
    1)页面较长,屏幕的可视区域有限
    2)不设置页面中img标签的src属性值或者将其指向同一个占位图
    3)图片的实际地址存在img标签自定义的一个属性中,如:“data-url”
    4)监听scroll,滚动到某个位置时,动态的将url替换成实际的“data-url”

  3. 流程图分析:
    在这里插入图片描述

  4. 代码实现
    html部分:

<!DOCTYPE html>
<html><head><meta charset="UTF-8"><title>Lazyload</title><style type="text/css">.mob-wrap li{list-style: none;width: 100%;height: 345px;}</style></head><body><ul class="mob-wrap"><li"><img class="tamp-img" alt="loading" data-src="http://mob.com/public/images/index/sharesdk-logo.jpg"><p>ShareSDK轻松实现社会化功能</p></li><li"><img class="tamp-img" alt="loading" data-src="http://mob.com/public/images/index/sms-logo.jpg"><p>短信验证码SDK</p></li><li"><img class="tamp-img" alt="loading" data-src="http://mob.com/public/images/index/rec-logo.jpg"><p>MobLink实现Web与App的无缝链接</p></li></ul></body>
</html>

js部分:

var aImg = [{"src":"http://mob.com/public/images/index/sharesdk-logo.jpg","txt":"ShareSDK轻松实现社会化功能"},{"src":"http://mob.com/public/images/index/sms-logo.jpg","txt":"短信验证码SDK"},{"src":"http://mob.com/public/images/index/rec-logo.jpg","txt":"MobLink实现Web与App的无缝链接"}
];
var sLi = '';
document.getElementsByClassName("mob-wrap")[0].innerHTML="";
for(let i = 0;i<10;i++){sLi = document.createElement("li");sLi.innerHTML = `<img class="tamp-img" alt="loading" src="./zwt.gif" data-src="${aImg[i%3].src}"><p>${aImg[i%3].txt}</p>`;document.getElementsByClassName("mob-wrap")[0].appendChild(sLi);
};window.onscroll = function () {var bodyScrollHeight =  document.documentElement.scrollTop;// body滚动高度var windowHeight = window.innerHeight;// 视窗高度var imgs = document.getElementsByClassName('tamp-img');for (var i =0; i < imgs.length; i++) {var imgHeight = imgs[i].offsetTop;// 图片距离顶部高度 if (imgHeight  < windowHeight  + bodyScrollHeight - 340) {imgs[i].src = imgs[i].getAttribute('data-src');imgs[i].className = imgs[i].className.replace('tamp-img','');}}
};

二、Lazyload的再优化

  1. 不做任何处理直接监听scroll必然导致在滚动鼠标滚轮的时候,过于频繁的触发处理函数。如果刚巧在处理函数中有大量的操作dom等消耗性能的行为,引发大量操作,导致页面变卡变慢,甚至浏览器崩溃无响应,处理这种问题的思路是节流和防抖
  2. 节流函数的形象比喻,比如在接咖啡的时候,按了一次按钮会出咖啡,紧跟着再按几次按钮接到的还是那一杯咖啡,相当于后面几次按的没有起作用
  3. 每隔least时间内至少执行一次的节流函数
    1)代码如下:
//节流函数
_throttle = (fn, delay, least) => {var timeout = null,startTime = new Date();fn();return function() {var curTime = new Date();clearTimeout(timeout);if(curTime - startTime >= least) {fn();startTime = curTime;}else {timeout = setTimeout(fn, delay);}}
}

2)使用节流函数:
代码如下:

function compare () {var bodyScrollHeight =  document.documentElement.scrollTop;// body滚动高度console.log(bodyScrollHeight+"替换src方法")var windowHeight = window.innerHeight;// 视窗高度var imgs = document.getElementsByClassName('tamp-img');for (var i =0; i < imgs.length; i++) {var imgHeight = imgs[i].offsetTop;// 图片距离顶部高度 if (imgHeight < windowHeight + bodyScrollHeight - 340) {imgs[i].src = imgs[i].getAttribute('data-src');imgs[i].className = imgs[i].className.replace('tamp-img','');}}
}
window.onscroll = _throttle(compare, 350,600);

3)说明:滚动时间least长于600,调用compare,否则延迟350ms执行。这样相对于直接onscroll性能得到更进一步提升,在功能上也没有什么问题,不同的业务场景调整一下delay和least就可以

http://www.yayakq.cn/news/542685/

相关文章:

  • 做商城网站哪里好哪些网站建设公司好
  • 国内优秀公司网站班级优化大师下载
  • wordpress网站响应很慢delphi网站开发
  • 企业做网站的费用如何科目广告制作公司属于什么行业类别
  • 长春网站seo哪家好搭建的wordpress没显示出来
  • 网站界面分类go网站做富集分析
  • 做网站的公司排名如何自建网站 卖东西
  • 铭誉摄影网站1688购物平台
  • 福田专业做网站公司如何制作自己的网站
  • 建一个全部由自己控制的网站需要多少钱网站如何做ICP备案
  • 网站空间 虚拟主机沈阳网站页面设计公司
  • 合肥网站建设卫来科技公众平台是什么
  • 分答网站学校网站建设与维护
  • 济南助企网站建设公司怎么样精准客户截流软件
  • 含山县查询建设工程的网站公司网页设计作品
  • 织梦网站站标自适应企业网站源码
  • 怎么查网站备案域名备案wordpress the7 seo
  • 网站建设及管理基本要求湖南省郴州市旅游景点介绍
  • 企业网站的价值体现是在工程建设科学技术奖申报网站
  • 怎么自己的电脑做网站仿豆瓣 wordpress
  • 网站建设公司哪些主要哪些动画制作软件手机版
  • 南宁网站设计运营广告设计图片大全 模板
  • 五种类型网站购买域名网站好
  • 成都网站建设中心张北北京网站建设
  • 用什么程序做网站好家具网站php源码
  • 如何做网站导航栏如何在360做网站SEO
  • 手机网站建设的公司排名查询企业信息
  • 国外做鞋子的网站有哪些云存储wordpress
  • 广西梧州市住房和城乡建设局网站wordpress耗时
  • 网站验收网站备案怎么那么麻烦