JS scroll系列简明教程

2024-05-09 10:32
文章标签 教程 js 系列 简明 scroll

本文主要是介绍JS scroll系列简明教程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、scroll团队成员

scroll,滚动,一般讨论的是网页整体与浏览器之间的关系。

浏览器的的宽高是固定的,但是页面的一般高度都远远大于浏览器的高度,有时候宽度也会大于浏览器的宽度。

Js中有一些系列的方法scroll的方法和属性。

打开经典的W3c,看一下Dom Element对象关于scroll的属性。

属性/方法解释
element.scrollHeight返回元素的整体高度。
element.scrollWidth返回元素的整体宽度。
element.scrollLeft返回元素左边缘与视图之间的距离。
element.scrollTop返回元素上边缘与视图之间的距离。

这四个属性,全部是只读属性。

其中,无非就是分为宽高左上
两个方向。

image.png

准备工作

想要研究页面滚动时,页面和浏览器的之间的关系,那么首先,我们应该拥有一个页面滚动的监听方法

伪代码

 

监听方法{// scrollHeight// scrollTop
}

方向是没错的,但是过程是曲折的。

最简单的 监听方法
window.onscroll = function() { 页面滚动语句 }

但是,这样是不行的,有兼容性问题。,在不同的浏览器下会有不同的监听方法,所以我们应该先准备一个通用的方法,做好兼容工作。(万恶的碎片化!!!)

具体的差异

  • 谷歌浏览器 和没有声明 DTD :
    document.body.scrollTop;
  • 火狐 和其他浏览器
    document.documentElement.scrollTop;
  • ie9+ 和 最新浏览器 都认识
    window.pageXOffset; pageYOffset (scrollTop)

==兼容的封装方法==

兼容不同浏览器,返回Json格式的宽和高

 

<script>// var json = {left: 10, right: 10} 变异//json.left json.topfunction scroll() {if(window.pageYOffset != null) // ie9+ 和其他浏览器{return {left: window.pageXOffset,top: window.pageYOffset}}else if(document.compatMode == "CSS1Compat") // 声明的了 DTD// 检测是不是怪异模式的浏览器 -- 就是没有 声明<!DOCTYPE html>{return {left: document.documentElement.scrollLeft,top: document.documentElement.scrollTop}}return { // 剩下的肯定是怪异模式的left: document.body.scrollLeft,top: document.body.scrollTop}}window.onscroll = function() {console.log(scroll().top);}
</script>

二、scrollLeft 和 scrollTop

获取scrollLeft 和 scrollTop。

根据封装好的方法,我们在页面上放置了一个 100*100 px的盒子。
进行一下滚动,基于可以在控制台看到很多即时打印的数据。

 

<!DOCTYPE html>
<html>
<head lang="en"><meta charset="UTF-8"><title></title><style>body {height: 3000px;margin: 0px;padding: 0px;}#div0{width: 100px;height: 100px;background: red;}</style>
</head>
<body>
<div id="div0"></div>
</body>
</html>
<script>// var json = {left: 10, right: 10} 变异//json.left json.topfunction scroll() {if(window.pageYOffset != null) // ie9+ 和其他浏览器{return {left: window.pageXOffset,top: window.pageYOffset}}else if(document.compatMode == "CSS1Compat") // 声明的了 DTD// 检测是不是怪异模式的浏览器 -- 就是没有 声明<!DOCTYPE html>{return {left: document.documentElement.scrollLeft,top: document.documentElement.scrollTop}}return { // 剩下的肯定是怪异模式的left: document.body.scrollLeft,top: document.body.scrollTop}}window.onscroll = function() {console.log("top: "+scroll().top);console.log("left: "+scroll().left);}
</script>

.
.
效果

image.png

 

.
.

小结图

image.png

.
.

三、 scrollHeight 和 scrollWidth

scrollHeight和scrollWidth类似,我们以scrollHeight为例子。

  • 使用scrollHeight和scrollWidth属性返回元素的高度,单位为px,包括padding
  • scrollHeight 和 scrollWidth返回的数值是包括当前不可见部分的。
  • scrollHeight 和 scrollWidth 属性为只读属性

栗子

 

<!DOCTYPE html><html><head><meta charset="UTF-8"><style>#myD {margin-top: 10px;height: 200px;width: 250px;/*内容溢出设置*/overflow: auto;}/*一个内容高度远比容器高度的例子*/#content {height: 500px;width: 1000px;padding: 10px;background-color: lightblue;}</style>
</head><body>
<p>点击以下按钮,获取id="content"的div元素的宽度和高度</p>
<button onclick="myFc()">按钮</button>
<div id="myD"><div id="content">内容</div>
</div>
<p id="demo"></p><script>function myFc() {var elmnt = document.getElementById("content");var y = elmnt.scrollHeight;var x = elmnt.scrollWidth;document.getElementById("demo").innerHTML = "高度: " + y + "px<br>宽度: " + x + "px";}</script>
</body>
</html>

.
.

结果:

 

image.png

小结图

image.png

上面介绍的四个属性,是从属于元素的。

.
.


Element对象关于scroll的属性 小结图

image.png


.
.

window对象的scrollBy() 和scrollTo()

scrollBy()和scrollTo()方法是从属于window对象的。

scrollBy(x,y)

scrollBy(x,y)方法滚动当前window中显示的文档,x和y指定滚动的相对量。

scrollBy(0, 200) ==> 使得滚动条Y轴的位置,在当前的基础上增加200。比如:当前Y轴位置为0,执行后便是200;当前为100,执行后便是300。

  • 要使此方法工作 window 滚动条的可见属性必须设置为true!

 

<!DOCTYPE html>
<html>
<head><meta charset="utf-8"><title>test</title><script>function scrollWindow(){//x轴方向的的变化用得少window.scrollBy(100,100);}</script>
</head>
<body><input type="button" onclick="scrollWindow()" value="滚动条" /><div style="width: 200px; height: 500px; background: darkcyan;font-size: 50px">001</div>
<div style="width: 200px; height: 500px; background: orange;font-size: 50px">002</div>
<div style="width: 200px; height: 500px; background: olivedrab;font-size: 50px">003</div>
<div style="width: 200px; height: 500px; background: aqua;font-size: 50px">004</div>
<div style="width: 200px; height: 500px; background: grey;font-size: 50px">005</div></body>
</html>

.
.
效果

image.png

 

scrollTo(x,y)

语法

 

scrollTo(xpos,ypos)
  • xpos 必需。要在窗口文档显示区左上角显示的文档的 x 坐标。
  • ypos 必需。要在窗口文档显示区左上角显示的文档的 y 坐标。

作用

scrollTo(x,y)方法:滚动当前window中显示的文档,让文档中由坐标x和y指定的点位于显示区域的左上角

scrollTo(0, 200) ==> 同scroll()方法,设置Y轴在200像素的位置。

示例

 

<!DOCTYPE html>
<html>
<head><meta charset="utf-8"><title>test</title><script>function scrollWindow(){//x轴方向的的变化用得少window.scrollTo(0,1200);}</script>
</head>
<body><input type="button" onclick="scrollWindow()" value="滚动条" /><div style="width: 200px; height: 500px; background: darkcyan;font-size: 50px">001</div>
<div style="width: 200px; height: 500px; background: orange;font-size: 50px">002</div>
<div style="width: 200px; height: 500px; background: olivedrab;font-size: 50px">003</div>
<div style="width: 200px; height: 500px; background: aqua;font-size: 50px">004</div>
<div style="width: 200px; height: 500px; background: grey;font-size: 50px">005</div></body>
</html>

.
.
效果:

image.png



作者:阿敏其人
链接:https://www.jianshu.com/p/cd5ba22a416d
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

这篇关于JS scroll系列简明教程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/973164

相关文章

springboot使用Scheduling实现动态增删启停定时任务教程

《springboot使用Scheduling实现动态增删启停定时任务教程》:本文主要介绍springboot使用Scheduling实现动态增删启停定时任务教程,具有很好的参考价值,希望对大家有... 目录1、配置定时任务需要的线程池2、创建ScheduledFuture的包装类3、注册定时任务,增加、删

如何为Yarn配置国内源的详细教程

《如何为Yarn配置国内源的详细教程》在使用Yarn进行项目开发时,由于网络原因,直接使用官方源可能会导致下载速度慢或连接失败,配置国内源可以显著提高包的下载速度和稳定性,本文将详细介绍如何为Yarn... 目录一、查询当前使用的镜像源二、设置国内源1. 设置为淘宝镜像源2. 设置为其他国内源三、还原为官方

Maven的使用和配置国内源的保姆级教程

《Maven的使用和配置国内源的保姆级教程》Maven是⼀个项目管理工具,基于POM(ProjectObjectModel,项目对象模型)的概念,Maven可以通过一小段描述信息来管理项目的构建,报告... 目录1. 什么是Maven?2.创建⼀个Maven项目3.Maven 核心功能4.使用Maven H

IDEA自动生成注释模板的配置教程

《IDEA自动生成注释模板的配置教程》本文介绍了如何在IntelliJIDEA中配置类和方法的注释模板,包括自动生成项目名称、包名、日期和时间等内容,以及如何定制参数和返回值的注释格式,需要的朋友可以... 目录项目场景配置方法类注释模板定义类开头的注释步骤类注释效果方法注释模板定义方法开头的注释步骤方法注

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

Python虚拟环境终极(含PyCharm的使用教程)

《Python虚拟环境终极(含PyCharm的使用教程)》:本文主要介绍Python虚拟环境终极(含PyCharm的使用教程),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录一、为什么需要虚拟环境?二、虚拟环境创建方式对比三、命令行创建虚拟环境(venv)3.1 基础命令3

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例

python连接本地SQL server详细图文教程

《python连接本地SQLserver详细图文教程》在数据分析领域,经常需要从数据库中获取数据进行分析和处理,下面:本文主要介绍python连接本地SQLserver的相关资料,文中通过代码... 目录一.设置本地账号1.新建用户2.开启双重验证3,开启TCP/IP本地服务二js.python连接实例1.

Python 安装和配置flask, flask_cors的图文教程

《Python安装和配置flask,flask_cors的图文教程》:本文主要介绍Python安装和配置flask,flask_cors的图文教程,本文通过图文并茂的形式给大家介绍的非常详细,... 目录一.python安装:二,配置环境变量,三:检查Python安装和环境变量,四:安装flask和flas