页面滚动图片等元素动态加载实现本质

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

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

假设: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 

  }   

})()

posted @   yupeng  阅读(677)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· [AI/GPT/综述] AI Agent的设计模式综述
点击右上角即可分享
微信分享提示