当前位置: 首页 > news >正文

6生肖竞猜网站建设百度高级搜索功能

6生肖竞猜网站建设,百度高级搜索功能,免费咨询医生妇科医生,重庆建设厅网站首页Ⅰ、前言 「懒加载」是网页中非常 常见的;为了减少系统的压力,对于一些电商系统出场频率非常高;那么大家一般用什么方式去实现 「懒加载」 呢 ? ① 通过 scroll 的形式: 通过 滚动「scroll」事件,然后去判…

Ⅰ、前言

  • 懒加载是网页中非常 常见的;
  • 为了减少系统的压力,对于一些电商系统出场频率非常高;
  • 那么大家一般用什么方式去实现 懒加载 呢 ?

在这里插入图片描述
① 通过 scroll 的形式:

通过 滚动scroll事件,然后去判断距离,当 距离到达一定范围,判断是否要加载资源;


② 通过 IntersectionObserver 的形式:

通过 元素与设备视窗或者其他指定元素发生交集的时候 => 最底部的元素滚动到视口时 ,判断是否要加载资源;

优势:

  • IntersectionObserver不像scroll事件触发那么频繁 , 对系统压力更小 ;
  • 不用计算距离,使用起来更加简单 ;

Ⅱ、概念与用法

  • IntersectionObserver 构造函数需要传入一个回调函数;
  • 首次加载元素与视窗发生交集 (或指定元素) 会执行这个回调函数;
  • 通过 observer 方法给定一个元素观察;
  const observer = new IntersectionObserver(callback);observer.observe(dom);

Ⅲ、用交叉观察器实现懒加载

  • 首先我们创建 content 用存放内容,每次加载再向其中加入更多内容 ;
  • 用 交叉观察器(IntersectionObserver) 监听 <footer> 标签, 首次触发一下,当 <footer> 滚动到页面上时
  • 然后写一个 添加的方法(例 :addItem),每次添加10条内容;
  • 过程如下 👇
<body><div class="content"></div><footer> 加载中。。。 </footer>
</body>
<script>const footer = document.getElementsByTagName('footer')[0]const observer = new IntersectionObserver((val) => {addItem();});observer.observe(footer);const content = document.getElementsByClassName('content')[0]let num = 0;function addItem() {for (let i = num; i < num+10; i++) {let node = document.createElement("div");node.innerText = `${i+1}`node.className = 'item'box.appendChild(content)}num = num + 10;}
</script>
  • 查看效果 👇

在这里插入图片描述

  • 再添加一点样式 ,完整例子 👇
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title>
</head>
<style>.item {height: 100px;box-sizing: border-box;border-bottom: 1px solid red;background: orange;width: 300px;text-align: center;line-height: 100px;margin: 0 auto;}body {padding: 0;margin: 0;}footer {width: 300px;margin: 0 auto;height: 50px;margin: 0 auto;background: aqua;text-align: center;line-height: 50px;}
</style><body><div class="box"></div><footer> 加载中。。。 </footer>
</body>
<script>const footer = document.getElementsByTagName('footer')[0]const observer = new IntersectionObserver((val) => {setTimeout(addItem, 300);});observer.observe(footer);const box = document.getElementsByClassName('box')[0]let num = 0;function addItem() {for (let i = num; i < num + 10; i++) {let node = document.createElement("div");node.innerText = `${i + 1}`node.className = 'item'box.appendChild(node)}num = num + 10;}
</script>
</html>

在这里插入图片描述

http://www.tj-hxxt.cn/news/43005.html

相关文章:

  • 教育类手机网站模板下载网络营销策略的特点
  • 网站违规词处罚做网站的曲靖新闻今日头条
  • b站直播能禁止id观看吗北京网站seo设计
  • 企业商务网站设计与开发查询网站域名
  • 北京网站建设亿玛酷专注4网站关键词在哪里看
  • 怎样做动态网站seo泛目录培训
  • 做地产网站哪家好最新网站查询工具
  • 做网站应该买哪一种服务器公司网址怎么注册
  • 制作网站项目实例aso优化公司
  • 微信小程序怎么制作流程上海百度关键词优化公司
  • 网站怎么做悬浮图片放大seo优化的技巧
  • 高校廉洁文化建设网站站内关键词自然排名优化
  • 制作公司网站价格淘宝怎么优化关键词排名
  • php网站怎么做seo广州网络优化最早的公司
  • 佛山网站建设 天博seo排名软件免费
  • 网站建设公司天强科技百度手机卫士下载安装
  • 两峡一峰旅游开发公司官方网站360搜索引擎优化
  • 个人网站建设 实验报告全网营销系统
  • 昆明网站排名优化公司哪家好网站关键词快速排名工具
  • 厦门网络建站公司培训机构网站制作
  • 吉林企业做网站免费关键词排名优化
  • 为什么做的网站搜不出来的网站关键词优化有用吗
  • 如何添加网站板块市场营销推广方案
  • 申请空间 建立网站吗宁德市医院
  • 专门做孕婴用品的网站seo站点
  • 青岛做网站哪家专业网站seo快速优化
  • wordpress对网站排名seo发展前景怎么样啊
  • 一般网站做响应式吗seo咨询推广
  • 灯饰网站开发seo推广优化公司哪家好
  • 可用来制作网页的软件有东莞seo关键词排名优化排名