jquery监听页面滚动距离,jQuery 滚动到页面指定元素位置,jquery滑动滚动条到指定元素, jquery 判断div滚动条是否滚动到底部

jquery监听页面滚动距离

//在文档加载完毕后执行
$(document).ready(function(){
	//开始监听滚动条
	$(window).scroll(function(){
		var top = $(document).scrollTop();
		console.log(top);
	})
})


参考 https://blog.csdn.net/qq_41009420/article/details/120485139

jquery 判断div滚动条是否滚动到底部

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
   <html xmlns="http://www.w3.org/1999/xhtml">
   <head>
     <meta http-equiv="content-type" content="text/html;charset=utf-8">
     <title>下拉滚动条滚到底部了吗?</title>
     <script language="javascript" src="jquery-1.4.2.min.js" mce_src="jquery-1.4.2.min.js"></script>
     <script language="javascript">
     $(document).ready(function (){
       var nScrollHight = 0; //滚动距离总长(注意不是滚动条的长度)
       var nScrollTop = 0;   //滚动到的当前位置
       var nDivHight = $("#div1").height();
       $("#div1").scroll(function(){
         nScrollHight = $(this)[0].scrollHeight;
         nScrollTop = $(this)[0].scrollTop;
         if(nScrollTop + nDivHight >= nScrollHight)
           alert("滚动条到底部了");
         });
     });
     </script>
   <body>
   <div id="div1" style="overflow-y:auto; overflow-x:hidden; height:500px;">
     <div style="background-color:#ccc; height:750px;">IE 和 FF 下测试通过</div>
   </div>
   </body>
   </html>

jquery滑动滚动条到指定元素

//$(this):指定元素对象
//$(this).offset().top:指定元素的头部位置高度(若滑动位置高度不确定,可用该方式加减数字,偏移滑动位置)

//瞬间完成滑动
$("html,body").scrollTop($(this).offset().top);

//耗时1秒时间,滑动到指定元素(动效)
$('html,body').animate({
	scrollTop : $(this).offset().top
}, 1000);

//1秒以后再滑动到指定元素(若页面元素尚未渲染,可待其渲染后再滑动)
setTimeout(function(){
	$("html,body").scrollTop($(this).offset().top);
}, 1000);

演示地址 https://wow.techbrood.com/fiddle/10031

方法1

jQuery实现点击某元素页面滚动到相应位置
点击某元素滚动到某个元素id的位置》

<div id="morecolor">让页面滚动到我这里来</div>
1
$('html , body').animate({scrollTop: $('#morecolor').offset().top}, 1000);

————————————————
版权声明:本文为CSDN博主「五颜六色的黑」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_38483133/article/details/86534439

方法2

HTML

<ul id="commentlist">
    <li style="text-align: left">
        <img src="" alt="">
        <p class="name">iefreer</p>
        <span class="time">2015-07-17 16:38:45</span>
        <p class="comment_content">comment1</p>
    </li>
    <li style="text-align: left">
        <img src="" alt="">
        <p class="name">iefreer</p>
        <span class="time">2015-07-17 16:38:25</span>
        <p class="comment_content">comment2</p>
    </li>
    <li style="text-align: left">
        <img src="" alt="">
        <p class="name">iefreer</p>
        <span class="time">2015-07-17 16:38:02</span>
        <p class="comment_content">comment3</p>
    </li>
    <li style="text-align: left">
        <img src="" alt="">
        <p class="name">iefreer</p>
        <span class="time">2015-07-17 16:38:45</span>
        <p class="comment_content">comment1</p>
    </li>
    <li style="text-align: left">
        <img src="" alt="">
        <p class="name">iefreer</p>
        <span class="time">2015-07-17 16:38:25</span>
        <p class="comment_content">comment2</p>
    </li>
    <li style="text-align: left">
        <img src="" alt="">
        <p class="name">iefreer</p>
        <span class="time">2015-07-17 16:38:02</span>
        <p class="comment_content">comment3</p>
    </li>
</ul>
<button id="scroll">Scroll me</button>

JavaScript

$(document).ready(function() {
    $("#scroll").click(function() {
        $('html, body').animate({
            scrollTop: $("#commentlist").offset().top
        }, 1000);
    });
});

CSS

#scroll {
    margin-bottom: 60px;
    padding: 5px 10px;
}

参考 https://blog.csdn.net/qq_24604781/article/details/125146087

相关知识

三. 相关知识

javascript中制作滚动代码的常用属性

1.网页可见区域宽: document.body.clientWidth;
网页可见区域高: document.body.clientHeight;
网页可见区域宽: document.body.offsetWidth (包括边线的宽);
网页可见区域高: document.body.offsetHeight (包括边线的宽);
网页正文全文宽: document.body.scrollWidth;
网页正文全文高: document.body.scrollHeight;
网页被卷去的高: document.body.scrollTop;
网页被卷去的左: document.body.scrollLeft;
网页正文部分上: window.screenTop;
网页正文部分左: window.screenLeft;
屏幕分辨率的高: window.screen.height;
屏幕分辨率的宽: window.screen.width;
屏幕可用工作区高度: window.screen.availHeight;

2.假设 obj 为某个 HTML 控件。

obj.offsetTop 指 obj 距离上方或上层控件的位置,整型,单位像素。
obj.offsetLeft 指 obj 距离左方或上层控件的位置,整型,单位像素。
obj.offsetWidth 指 obj 控件自身的宽度,整型,单位像素。
obj.offsetHeight 指 obj 控件自身的高度,整型,单位像素。

我们对前面提到的“上方或上层”与“左方或上层”控件作个说明。
例如:

<div id=”tool”>
<input type=”button” value=”提交”>
<input type=”button” value=”重置”>
</div>

“提交”按钮的 offsetTop 指“提交”按钮距“tool”层上边框的距离,因为距其上边最近的是 “tool” 层的上边框。
“重置”按钮的 offsetTop 指“重置”按钮距“tool”层上边框的距离,因为距其上边最近的是 “tool” 层的上边框。
“提交”按钮的 offsetLeft 指“提交”按钮距“tool”层左边框的距离,因为距其左边最近的是 “tool” 层的左边框。
“重置”按钮的 offsetLeft 指“重置”按钮距“提交”按钮右边框的距离,因为距其左边最近的是“提交”按钮的右边框。

以上属性在 FireFox 中也有效。

3.offsetTop 与 style.top 的区别

预备知识:offsetTop、offsetLeft、offsetWidth、offsetHeight
我们知道 offsetTop 可以获得 HTML 元素距离上方或外层元素的位置,style.top 也是可以的,二者的区别是:

(1)offsetTop 返回的是数字,而 style.top 返回的是字符串,除了数字外还带有单位:px。
(2)offsetTop 只读,而 style.top 可读写。
(3)如果没有给 HTML 元素指定过 top 样式,则 style.top 返回的是空字符串。

offsetLeft 与 style.left、offsetWidth 与 style.width、offsetHeight 与 style.height 也是同样道理。
offsetWidth与style.width属性的区别在于:如对象的宽度设定值为百分比宽度,则无论页面变大还是变小,style.width都返回此百分比,而offsetWidth则返回在不同页面中对象的宽度值而不是百分比值

4.scrollLeft :
对象的最左边到对象在当前窗口显示的范围内的左边的距离.
即是在出现了横向滚动条的情况下,滚动条拉动的距离.
scrollTop
对象的最顶部到对象在当前窗口显示的范围内的顶边的距离.
即是在出现了纵向滚动条的情况下,滚动条拉动的距离.

js代码

onload = function () {
  //初始化
  scrollToLocation();
};
function scrollToLocation() {
  var mainContainer = $('#thisMainPanel'),
  scrollToContainer = mainContainer.find('.son-panel:last');//滚动到<div id="thisMainPanel">中类名为son-panel的最后一个div处
  //scrollToContainer = mainContainer.find('.son-panel:eq(5)');//滚动到<div id="thisMainPanel">中类名为son-panel的第六个处
  //非动画效果
  //mainContainer.scrollTop(
  //  scrollToContainer.offset().top - mainContainer.offset().top + mainContainer.scrollTop()
  //);
  //动画效果
  mainContainer.animate({
    scrollTop: scrollToContainer.offset().top - mainContainer.offset().top + mainContainer.scrollTop()
  }, 2000);//2秒滑动到指定位置
}

HTML代码

<div id="thisMainPanel" style="height:200px;overflow-y: scroll;border:1px solid #f3f3f3;">
    <div class="son-panel">我是类容区域-1</div>
    <div class="son-panel">我是类容区域-2</div>
    <div class="son-panel">我是类容区域-3</div>
    <div class="son-panel">我是类容区域-4</div>
    <div class="son-panel" style="height:160px;">我是类容区域-5</div>
    <div class="son-panel">我是类容区域-6</div>
    <div class="son-panel">我是类容区域-7</div>
    <div class="son-panel">我是类容区域-8</div>
</div>

参考 https://blog.csdn.net/xyr05288/article/details/78613153

您可能还喜欢...

发表回复