zoukankan      html  css  js  c++  java
  • 页面滚动图片等元素动态加载实现本质

    各种网站经常看到页面滚动到可视区域,然后才加载相应的图片资源,他的本质是什么呢?本文来分析一下

    很简单,就是判断当前元素是否是可视区域内

    假设:h1 = 滚动条滚去的高度

       w1 = 滚动条滚去的宽度

       h2 = 屏幕的高度

         obj 表示当前对象 {x:当前对象相对于文档左上角的位置x,y:当前对象相对于文档左上角的y}

    则应该这样判断

      在y轴方向上:if(obj.x>h1&&obj.x<h1+h2||obj.x+obj.offsetHeight>h1&&|obj.x+obj.offsetHeight<h1+h2){loading()}

      同理在X轴方向上以此类推

    如果使用tangram框架的话可以这样写:

    baidu.more = baidu.more||{};

    baidu.more.scrollLoading = (function(){

      var top     = baidu.page.getScrollTop(),

        left     = baidu.page.getScrollLeft(),

        viewHeight  = baidu.page.viewHeight(),

        viewWidth  = baidu.page.viewWidth();

      var scrollLoad = function(element){

         var obj = baidu.g(element)||{};

         var pos = baidu.dom.getPosition(element);

        if((pos.top>top&&pos.top<top+viewHeight)||

          (pos.top+obj.offsetHeight>top&& pos.top+obj.offsetHeight<top+viewHeight)||

          (pos.left>left&&pos.left<left+viewWidth)||

          (pos.left+obj.offsetWidth>left&&pos.left+obj.offsetWidth<left+viewWidth)){

            loading();

      };

       return {

        scrollLoad :scrollLoad 

      }   

    })()

  • 相关阅读:
    判断是否是移动端
    html上传文件类型限制accept的全部属性值
    前端cropper裁剪图像大小(原创)
    eslint加不加分号
    手机浏览器使用rem 自适应html宽度大小
    DOMContentLoaded与load的区别
    ES6语法find查找匹配数组
    React的JSX语法
    React的基本使用
    React简介
  • 原文地址:https://www.cnblogs.com/yupeng/p/2403928.html
Copyright © 2011-2022 走看看