元素可视范围&懒加载

如何判断一个元素是否出现在窗口可视范围(浏览器的上边缘和下边缘之间,肉眼可视)。写一个函数 isVisible实现

为加深印象直接写出我测试的例子:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <script src="jquery.min.js"></script>
    <style>
        * {
            padding: 0;
            margin: 0;
            box-sizing: border-box;
            list-style: none;
        }

        li {
            background: aqua;
            height: 100px;
        }

        .middle {
            background: pink;
        }
    </style>
</head>

<body>
    <ul class="ct">
        <li>item 1</li>
        <li>item 2</li>
        <li>item 3</li>
        <li>item 4</li>
        <li>item 5</li>
        <li>item 6</li>
        <li>item 7</li>
        <li>item 8</li>
        <li>item 9</li>
        <li>item 10</li>
        <li class="middle">hello world</li>
        <li>item 1</li>
        <li>item 2</li>
        <li>item 3</li>
        <li>item 4</li>
        <li>item 5</li>
        <li>item 6</li>
        <li>item 7</li>
        <li>item 8</li>
        <li>item 9</li>
        <li>item 10</li>

    </ul>
    <script>
        function isVisible($node) {
            var scrollTop = $(window).scrollTop();//滚动条卷曲高度
            var windowHeight = $(window).height();//可视内容区高度
            var offsetTop = $node.offset().top;//node偏移高度

            if (offsetTop < scrollTop + windowHeight && offsetTop + $node.height() > scrollTop) {
                console.log('true')
                console.log(scrollTop)
                console.log(windowHeight)
                console.log(offsetTop)
            } else {
                console.log('false')
            }
        }
        isVisible($('.middle'))
    </script>
</body>

</html>

分析过程:
先上一张画的很粗糙的图——

大师兄所有,本图禁止转载!禁止转载!禁止转载!
  • 判断元素是否出现在浏览器的上边缘和下边缘之间,肉眼可视,首先要获取滚动条卷曲高度,可视内容区高度及node元素的偏移高度,先明白如何让node出现在我们肉眼所及之区域。
  • 由上图可清晰看出,当offsetTop = scrollTop + windowHeight时,node刚好完全处于可视区下边缘之下,所以offsetTop < scrollTop + windowHeight可确保node出现在可视区及滚动条卷曲的区域之间,所以下一步是确保node不出现在滚动条卷曲的区域,即offsetTop + $node.height() > scrollTop,需要注意的是这里的计算都是以node左上角点为原点。
  • 为什么要加上node自身的高度?因为当node出现在视野中,继续向下浏览页面,node会从视野上方消失,在完全消失之前,node对于肉眼来说仍是可见的,所以加上node的高度再去做计算,可以得到较为精确的结果。如果node高度值很大而你忽略了它,问题就会比较明显。

个人补充一题,如何判断一个元素是否滚动到了可视区域底部

与判断一个元素是否出现在窗口可视范围同理,直接看代码

$node = $('.middle');
var windowHeight = $(window).height();
var offsetTop = $node.offset().top;
$(window).on('scroll', function () {
    var scrollTop = $(window).scrollTop();//scrollTop是动态的,所以需要在函数內定义
    //我写的判断条件过于严苛,实际运用应该只用实现大致到了底部就好
    if ($node.height() + offsetTop - windowHeight == scrollTop) {//一般将动态值放在运算符右边
        console.log('true')
    } else {
        console.log('false')
    }
})

我写的判断条件过于严苛,所以较难捕获到true,实际运用应该只用实现大致到了底部就好

当窗口滚动时,判断一个元素是不是出现在窗口可视范围。每次出现都在控制台打印 true 。用代码实现

function isVisible($node) {
    var scrollTop = $(window).scrollTop();
    var windowHeight = $(window).height();
    var offsetTop = $node.offset().top;

    if (offsetTop < scrollTop + windowHeight && offsetTop + $node.height() > scrollTop) {
        return true
    } else {
        return false
    }
}

//写法一
$(window).on('scroll', function () {
    if (isVisible($('.middle'))) {
        console.log(true)
    }
})

//写法二
$(function () {
    $(window).scroll(function () {
        if (isVisible($('.middle'))) {
            console.log(true)
        }
    })
})

当窗口滚动时,判断一个元素是不是出现在窗口可视范围。在元素第一次出现时在控制台打印 true,以后再次出现不做任何处理。用代码实现

function isVisible($node) {
    var scrollTop = $(window).scrollTop();
    var windowHeight = $(window).height();
    var offsetTop = $node.offset().top;

    if (offsetTop < scrollTop + windowHeight && offsetTop + $node.height() > scrollTop) {
        return true
    } else {
        return false
    }
}

var isEleVisible = false
$(function () {
    $(window).scroll(function () {
        if (isVisible($('.middle')) && !isEleVisible) {
            console.log(true)
            isEleVisible = true
        }
    })
})

图片懒加载的原理是什么?

  • 首先明白为什么要懒加载:
    懒加载即延迟,对于图片过多的页面,为了加快页面加载速度,我们需要将页面内未出现在可视区域内的图片先不做加载, 等到滚动到可视区域后再去加载。
    这样一来页面加载性能大幅提升,提高了用户体验。
  • 实现原理:
    • 在页面载入时将img标签內的src指向一个小图片,即占位图,将真实地址存放于一个自定义属性data-src中,然后获取页面上的img标签并保存,开启一个定时器来遍历保存的img标签,接下来判断每个img是否出现在可视区,当某个img出现在了可视区域,就将真实地址赋值给该img的src并将该img从数组中删除以避免重复判断。
    • 我们需要判断元素是否出现在了可视区,以上第一题我做了详细解释,这里不重复说。
    • 实现流程:
      当网页滚动事件被触发➡️执行加载图片操作➡️判断图片是否在可视区且是否已经加载过➡️在可视区且未被加载过则动态地将data-src的值赋给该图片的src属性。

实现视频中的图片懒加载效果

我的实现

(选做)实现如下 新闻自动懒加载效果84 (这里是参考代码, 其中html里的为前端代码, js 里的内容为 router.js里的后端代码, 也可参考往前班级视频264)

mark一下之后再补充这个选做题


参考资料

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

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,725评论 1 92
  • 1.如何判断一个元素是否出现在窗口可视范围(浏览器的上边缘和下边缘之间,肉眼可视)。写一个函数 isVisible...
    GarenWang阅读 461评论 0 2
  • •前端面试题汇总 一、HTML和CSS 21 你做的页面在哪些流览器测试过?这些浏览器的内核分别是什么? ...
    Simon_s阅读 2,219评论 0 8
  • 找工作的常识:1.在国家企业信用信息公示系统 查询招聘企业信息;2.了解公司在本地的具体地址;3. 了解公司具体的...
    厚积爆发阅读 266评论 0 0
  • 放学时 子文第一次去接孩子放学时,走过川流不息的马路,风吹着丝巾,丝巾拂弄脸庞,痒痒的,子文轻轻浅浅的笑,又看看周...
    阿良啊阅读 199评论 0 0