半栈工程师程序员让前端飞

元素可视范围&懒加载

2017-09-12  本文已影响0人  _Dot912

如何判断一个元素是否出现在窗口可视范围(浏览器的上边缘和下边缘之间,肉眼可视)。写一个函数 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 = $('.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
        }
    })
})

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

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

我的实现

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

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


参考资料

上一篇 下一篇

猜你喜欢

热点阅读