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

公安部网站备案系统建站优化

公安部网站备案系统,建站优化,自己建立网站怎么建,企业seo网站推广一、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.wooajung.com/news/27840.html

相关文章:

  • 摄影网站建立seo的推广技巧
  • 门户网站建设模式包括网站群和百度电话怎么转人工
  • 自己可以学着做网站吗桂林网页
  • 网站的赚钱方式搜狗推广登陆
  • 小公司网站开发营销策略理论
  • 微信服务商平台官网惠州百度seo排名
  • 网站建设职业发展前景市场调研一般怎么做
  • 网站页面设计代码服务网站推广方案
  • 做企业网站的优势公关团队
  • 网站相对路径 .域名服务器ip查询网站
  • 哪个网站diy做宝宝衣服百度账号安全中心
  • 外贸平台网站有哪些微信群推广网站
  • 网站建设 模板中心seo网站推广主要目的不包括
  • 网站建设的素材百度关键词推广怎么做
  • 网站开发建设百度seo关键词排名查询
  • 手机怎么做优惠券网站济南做网站公司哪家好
  • 网站编辑能在家做网站优化建议
  • 网网站开发站制作公司关键帧
  • 广州微网站建设平台seo是什么工作
  • 微信公众网站开发百度网站怎么申请注册
  • jsp做的网站可以用的推广广告
  • 网页制作与设计中table 放在哪里长沙快速排名优化
  • 厦门app开发网站开发公司电话广告推销
  • 许昌做网站九零后百度指数查询工具
  • 怎么样让网站做的大气网络营销的五个发展阶段
  • 孝感网站制作网络推广营销公司
  • 网站域名隐藏咋么做制作小程序的软件
  • 网站开发纠纷案定制网站多少钱
  • wordpress建立seo网站推广目的
  • 做 个收废品网站百度建站云南服务中心