懒加载剖析

懒加载:

懒加载又称延迟加载,该技术的理念是按需加载。在一些大厂的产品中用的比较多,因为对页面渲染时间有严格限制。

应用懒加载的网站:

淘宝,京东,花瓣,美丽说...

相关概念:

  • 网页可视区宽(width + padding):
    document.body.clientWidth

  • 网页占位宽(width + padding + border):
    document.body.offsetWidth

clientWidth/offsetWidth示例
clientWidth/offsetWidth示例
  • 网页正文全文宽:
    document.body.scrollWidth

  • 网页正文被卷去的高度:
    其他:document.documentElement.scrollTop
    chrome: document.body.scrollTop
    兼容写法:document.documentElement.scrollTop || document.body.scrollTop

scrollTop兼容示例
scrollTop兼容示例
  • 获取元素绝对位置:
    offsetParent:定位父级:离自己最近的有定位的父级元素;没有手动设置定位父级的时候,默认定位父级为body。
    element.offsetTop:相对于父级的顶部偏移值;
    element.offsetLeft:相对于父级的左侧偏移值;
    不存在element.offsetRigthelement.offsetBottom属性;
获取定位值
获取定位值

宽高写法相同,不一一列举;

应用场景:

涉及到图片,falsh资源 , iframe, 网页编辑器(类似FCK)等占用较大带宽,且这些模块暂且不在浏览器可视区内,因此可以使用懒加载技术在某个模块容器到达了网页可见区域时,再使用ajax异步请求将请求内容渲染出来,避免网页打开时加载过多资源,让用户等待太久。

判断模块是否进入可视区:

当用户浏览到首屏之外的其他模块,也就是其他模块进入可视区时,异步加载进而渲染资源到页面。
因此实现懒加载的关键点是判断模块是否进入可视区,也可以把可视区理解成一个模块,首屏外的内容为一个模块,当两个模块发生碰撞时即需是加载资源的时机。
盗一张图解释说明下两个模块的临界点:

判断模块是否进入视口
判断模块是否进入视口

引入一个公式,以图二中的两个模块为例:

    //top1 = 文档顶部卷去的高度;
    //top2 = 元素相对于顶层定位父级的offsetTop值;
    //height1 = 文档可视区的高度;
    //height2 = 模块的高度;
    
    m1 = top1 + height1 / 2
    m2 = top2 + height2 / 2
    |m1 - m2| < (height1 + height2) / 2

上面的公式中height1、height2和top2都为常量,只有top1为变量;

    //假设:top1 = 0,top2 = 300, width = height = 300,则:
    m1 = 0 + 300 / 2 = 150;
    m2 = 300 + 300 / 2 = 450;
    |m1 - m2| = (height1 + height2) / 2;
    //此时为临界点,刚好相等;

    //假设:top1 = 100,top2 = 300, width = height = 300,则:
    m1 = 100 + 300 / 2 = 250;
    m2 = 300 + 300 / 2 = 450;
    |m1 - m2| < (height1 + height2) / 2;
    //值小于时说明相交了;

获取元素相对于顶层父级的绝对位置:

function getDstResource(ele){
    var l = 0,t = 0, w, h;
    //获取元素占位宽高
    w = ele.offsetWidth;
    h = ele.offsetHeight;
    while (ele.offsetParent){
        //获取元素偏移值
        l += ele.offsetLeft;
        t += ele.offsetTop;
        ele = ele.offsetParent;
    }
    return {'left':l,'top':t,'width':w,'height':h};
}

完整代码:

//获取可视区
function getVisiableZone(){
    var l,t,w,h;
    l = document.documentElement.scrollLeft || document.body.scrollLeft;
    t = document.documentElement.scrollTop || document.body.scrollTop;
    w = document.documentElement.clientWidth;
    h = document.documentElement.clientHeight;
    return {'left':l,'top':t,'width':w,'height':h};
}

//获取元素绝对位置
function getDstResource(ele){
    var l = 0,t = 0, w, h;
    //获取元素占位宽高
    w = ele.offsetWidth;
    h = ele.offsetHeight;
    while (ele.offsetParent){
        //获取元素偏移值
        l += ele.offsetLeft;
        t += ele.offsetTop;
        ele = ele.offsetParent;
    }
    return {'left':l,'top':t,'width':w,'height':h};
}

//判断两个长方形是否交叠
function overlap(rect1,rect2){
    var l1,l2,t1,t2,w,h;
    l1 = rect1.left + rect1.width / 2;
    l2 = rect2.left + rect2.width / 2;
    t1 = rect1.top + rect1.height / 2;
    t2 = rect2.top + rect2.height / 2;
    w = (rect1.width + rect2.width) / 2;
    h = (rect1.height + rect2.height) / 2;
    return Math.abs(l1 - l2) < w && Math.abs(t1 - t2) < h;
}

//异步加载
if(overlap(getVisiableZone(),getDstResource(document.getElementById("xxx")))){
    //相应的处理...
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,948评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,371评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,490评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,521评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,627评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,842评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,997评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,741评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,203评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,534评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,673评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,339评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,955评论 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,770评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,000评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,394评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,562评论 2 349

推荐阅读更多精彩内容