懒加载

作者: marmot_ning | 来源:发表于2017-09-23 00:46 被阅读0次

    懒加载

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

    测试

    当窗口滚动时,判断一个元素是不是出现在窗口可视范围。每次出现都在控制台打印 true 。用代码实现
    <script>
            $(window).on('scroll', function () {
                if (isVisible($node)) {
                    console.log(true)
                }
            })
    
           var $node = $('.test')
             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
                
            }
            return false
        }
    
      </script>
    

    测试

    当窗口滚动时,判断一个元素是不是出现在窗口可视范围。在元素第一次出现时在控制台打印 true,以后再次出现不做任何处理。用代码实现
     <script>
    
            var isEleVisible = false
            $(function () {
            $(window).scroll(function () {
            if (isVisible($node) && !isEleVisible) {
                console.log(true)
                isEleVisible = true
            }
            })
            })
    
    
           var $node = $('.test')
             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
                
            }
            return false
        }
       // console.log(isVisible($node))
      </script>
    

    测试

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

    预览

    相关文章

      网友评论

          本文标题:懒加载

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