美文网首页
懒加载-回到顶部

懒加载-回到顶部

作者: 饥人谷_任磊 | 来源:发表于2016-11-24 17:32 被阅读54次

问答:

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

当一个元素的底部不超过浏览器的上边缘(元素本身的高度+元素在文档中的的高度>滚动条滚动的距离),顶部不超过浏览器的下边缘(元素在文档中的高度<窗口的高度+滚动条滚动的距离),就可以说这个元素是在窗口的可视范围之内的。

    function isVisible($node){
        var nodeH = $node.height();//获取元素本身的高度
        var nodeTop = $node.offset().top;//获取元素在文档中的高度
        var scrollTop = $(window).scrollTop();//获取滚动条滚动的距离
        var winH = $(window).height();//获取窗口的高度。
        return (nodeH+nodeTop > scrollTop && nodeTop < scrollTop + winH ) ? true : false//条件判断。
    }

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

    $(window).on("scroll",function(){//对窗口添加滚动事件监听
        if(isVisible($node)){//如果函数返回为true时,即代表指定元素出现在窗口可视范围内
            console.log(true);//控制台打印true。
        }
    });
    function isVisible($node){
        var nodeH = $node.offset().top;//获取元素在文档中的高度
        var scrollTop = $(window).scrollTop();//获取滚动条滚动的距离
        var winH = $(window).height();//获取窗口的高度。
        return (nodeH < scrollTop + winH) ? true : false//进行距离判断。
    }

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

    var isLoad; //设置一个状态锁
    $(window).on("scroll",function(){
        if(isVisible($node) && isLoad){//如果函数返回为true,且状态锁为true时,控制台才打印true
            console.log(true);
            isLoad = false;//当元素第一次出现并且执行代码后,使状态锁为false,这样元素下次再出现时不在做任何处理。
        }
    });
    function isVisible($node){
        var nodeH = $node.offset().top;//获取元素在文档中的高度
        var scrollTop = $(window).scrollTop();//获取滚动条滚动的距离
        var winH = $(window).height();//获取窗口的高度。
        return (nodeH < scrollTop + winH) ? true : false//进行距离判断。
    };

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

将图片地址存放在自定义属性中,当完成某种事件操作后,再将图片地址放在正常的img属性中,完成图片的加载。这样做的好处是能大大减少网页加载的时间。

代码:

1.实现如下回到顶部效果,当页面滚动到一定距离时,窗口右下角会出现回到顶部按钮,点击按钮页面会滚动到顶部。

代码地址
预览地址

2.实现如下图片懒加载效果

代码地址
预览地址

3.实现如下无限滚动效果

代码地址
预览地址
代码3本地测试成功。


本文版权归本人和饥人谷所有,转载请注明来源。

相关文章

  • 懒加载-回到顶部

    问答: 1.如何判断一个元素是否出现在窗口可视范围(浏览器的上边缘和下边缘之前,肉眼可见)。写一个函数isVisi...

  • jquery懒加载、回到顶部

    1.知识点部分: 懒加载图片的原理是什么? 图片懒加载也称为曝光加载,将页面上的图片分批加载,只有当图片出现在wi...

  • juery懒加载,回到顶部

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

  • jquery懒加载、回到顶部

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

  • jquery懒加载、回到顶部

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

  • jquery懒加载、回到顶部

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

  • jquery懒加载、回到顶部

    本教程版权归小圆和饥人谷所有,转载须说明来源 问答 1. 如何判断一个元素是否出现在窗口可视范围(浏览器的上边缘和...

  • jquery懒加载、回到顶部

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

  • jquery懒加载、回到顶部

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

  • jquery懒加载、回到顶部

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

网友评论

      本文标题:懒加载-回到顶部

      本文链接:https://www.haomeiwen.com/subject/buhspttx.html