div滑动到可视区_js检测页面上一个元素是否已经滚动到了屏幕的可视区域内

应用场景:

只要页面加载了,其中在页面中出现的li就向控制台输出第几个发送请求;在本次加载的页面中,再将滚动条滚回前边的li,不再向控制台输出东西,也就是说已经显示过的li,不再向控制台输出东西。

  • 0001
  • 0002
  • 0003
  • 0004
  • 0005
  • 0006
  • 0007
  • 0008
  • 0009
  • 00010
  • 00011
  • 00012
  • 00013
  • 00014
  • 00015
  • 00016
  • 00017
  • 00018
  • 00019
  • 00020
  • 00021
  • 00022

思路一:

定义了一个全局变量lastItem,用来记下最后显示的li的index;如此,当li的index>lastItem,就表示li还没展示过,能输出东西。

var lastItem=0;

$(document).ready(function () {

sendAsk();

window.addEventListener("scroll",function(e){

sendAsk();

});

});

function sendAsk(){

var lis= $('ul').find("li");

//swHeight=滚动的高度+窗体的高度;当li的offset高度<=swHeight,那么说明当前li显示在可视区域了

var swHeight=$(window).scrollTop()+$(window).height();

$.each(lis, function (index, item) {

mTop=item.offsetTop;

var dItem=index+1;

if(mToplastItem){

console.log(index+1+"个发送请求 ");

lastItem+=1;

}

});

}

思路二:

给每个li动态添加一个属性,用来表示这个li是否显示过;在发送请求后,设置属性为true即可;未显示过不添加属性即可。

function sendAsk() {

var lis= $('ul').find("li");

//swHeight=滚动的高度+窗体的高度;当li的offset高度<=swHeight,那么说明当前li显示在可视区域了

var swHeight=$(window).scrollTop()+$(window).height();

$.each(lis, function (index, item) {

mTop=item.offsetTop;

if(mTop

console.log(index+1+"个发送请求 ");

item.setAttribute("data-send","true");

}

});

}

思路三:

利用getBoundingClientRect()方法,只要其中的.top<=可视区域的高度即可

function sendAsk(){

var lis= $('ul').find("li");

//swHeight=滚动的高度+窗体的高度;当li的offset高度<=swHeight,那么说明当前li显示在可视区域了

var swHeight=$(window).height();

$.each(lis, function (index, item) {

mTop=item.getBoundingClientRect().top;

console.log(mTop);

if(mTop<=swHeight){

console.log(index+1+"个发送请求 ");

}

});

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值