操作滚动条可以通过锚点跳转,JS操作滚动条,与scrollIntoView等方法。对此,我来考古一下。

锚点跳转滚动滚动条

网页中的锚点跳转是HTML早期功能之一,锚点(anchor)跳转是1991年发布的HTML标准的一部分,这是超文本链接的基本特性

锚点跳转通过使用<a>标签的href属性来创建指向页面内部某个ID或名称(使用id或name属性标记的)的链接来实现。

<!-- 目标位置 -->
<div id="section1">This is Section 1</div>
**************长内容********************
<!-- 页内跳转链接,条件跳转到 Section 1-->
<a href="#section1">Jump to Section 1</a>

即使是最早的Web浏览器,如NCSA Mosaic,也支持页面内通过锚点进行跳转!

关于浏览器历史,参看:《浏览器史话中chrome霸主地位的奠定与国产浏览器的割据混战

浏览器始祖NCSA Mosaic在1993年1月发布(于1992年末由国家超级计算机应用中心—National Center for Supercomputing Applications开发)。Mosaic可以同时展示文字和图片,从此浏览器变得有趣多了。 在当时人气爆发的大受欢迎。Mosaic的出现,算是点燃了后期互联网热潮的火种之一。NCSA将Mosaic的商业运营权转售给了Spyglass公司,该公司又向包括微软公司在内的多家公司技术授权,允许其在 Mosaic的基础上开发自己的产品

1994年10月13日,网景通信公司推出发布了Mosaic Netscape 0.9

1994年开始,网景通信公司推出了代号为Netscape Navigator 1.0(网景导航者、网景浏览器),随后迭代版本迅速占领浏览器大部分份额。Netscape自称“Mozilla/1.0(Win3.1)”,一说 Mozilla = Mosaic + Killer,意为Mosaic杀手,也有说法是 Mozilla = Mosaic & Godzilla,意为马赛克和哥斯拉,而Mozilla最初的吉祥物是只绿色大蜥蜴,后来更改为红色暴龙,跟哥斯拉长得一样。

1995年起搭载cookie、框架和JavaScript等多样独自功能的2.0版上市。从前前端码农开始可以大踏步干活了,与通宵达旦干兼容血战到底。网景支持框架(frame),但是Mosaic不支持框架,于是网站管理员探测user agent,对Mozilla浏览器发送含有框架的页面,对非Mozilla浏览器发送没有框架的页面。

关于JavaScript,参看:《ECMAScript进化史(1):话说Web脚本语言王者JavaScript的加冕历史》与《JS引擎(0):JavaScript引擎群雄演义—起底JavaScript引擎

1995年Sun公司将Oak语言改名为Java,正式向市场推出(次年,LiveScript改名为JavaScript)。

Sun公司大肆宣传,许诺这种语言可以"一次编写,到处运行"(Write Once, Run Anywhere),它看上去很可能成为未来的主宰。

网景公司动了心,决定与Sun公司结成联盟。它不仅允许Java程序以applet(小程序)的形式,直接在浏览器中运行;甚至还考虑直接将Java作为脚本语言嵌入网页,只是因为这样会使HTML网页过于复杂,后来才不得不放弃。总之,当时的形势就是,网景公司的整个管理层,都是Java语言的信徒,Sun公司完全介入网页脚本语言的决策

1995年4月,网景公司录用34岁Brendan Eich( JavaScript 之父 闪亮登场)。

Brendan Eich被指定为这种"简化版Java语言"的设计师。但是,他对Java一点兴趣也没有。为了完成(应付)公司安排的任务,他只用10天时间就把JavaScript设计出来了。虽然语言的设计者水平非常NB,但谁也架不住“时间紧,任务重”。由于设计时间太短,语言的一些细节考虑得不够严谨,导致后来很长一段时间,Javascript写出来的程序混乱不堪。如果不是公司的决策,Brendan Eich绝不可能把Java作为Javascript设计的原型。作为设计者,他都不喜欢这个作品!

1995年浏览器有JavaScript 功能,可以通过JavaScript 手动更爱hash进行跳转

window.location.hash="section1"

JavaScript操作滚动条,还是不尽人意

操作滚动条滚动

1997年,JavaScript由ECMA International采纳为标准(ECMAScript),从而确保了不同浏览器之间的一致性和兼容性

scroll和scrollTo在现代浏览器中都支持的

// 使用scrollTo滚动页面到指定位置(100px, 100px)
window.scrollTo(100, 100); // 使用scroll执行相同的操作
window.scroll(100, 100);

允许你指定滚动行为(如是否平滑滚动):

// 使用对象参数带有平滑滚动
window.scrollTo({ top: 100, left: 100, behavior: 'smooth' }); // 使用scroll实现同样的滚动效果
window.scroll({ top: 100, left: 100, behavior: 'smooth' });

但是要滚动锚点位置,需要计算滚动的位置,如果是嵌套套娃,就非常复杂——可以复习下:《再谈BOM和DOM(6):dom对象及event对象位值计算—如offsetX/Top,clentX

这个方法,我劝读者放弃!

scrollIntoView滚动到指定为止

2000年,DOM2规范 带来了scrollIntoView API,但是微软从屠龙少年变恶龙后,就奔对新规范置之不理了!——这个API目前除了IE,可以放心用!

document.getElementById("section1").scrollIntoView();
// 或者
document.querySelector("#section1").scrollIntoView(true);

更加精细化控制:

element.scrollIntoView({ behavior: "smooth", block: "end", inline: "nearest" });

具体查看:https://developer.mozilla.org/en-US/docs/Web/API/Element/scrollIntoView

animate大法

是否还记得jquery时代的(2006年8月发布的jquery1.0 版本就推出了animate)

$("#button").click(function() {
  $("html, body").animate({
    scrollTop: $("#section1").offset().top }, {duration: 500,easing: "swing"});
    return false;
});

animate()方法使得很容易对CSS属性实施动画效果,并且随着jQuery库的普及,animate()方法也迅速成为一个广为人知的标准做法。

css过去及未来展望—分析css演进及排版布局的考量

1999年,CSS 3的草稿开始制定

2001年5月23日W3C完成了CSS3的工作草案,主要包括盒子模型、列表模块、超链接方式、语言模块、背景和边框、文字特效、多栏布局等模块

2005 年 12 月,W3C 开始 CSS3 标准的制定。css是有一系列的标准组成。每个系列完成的时间不一样。所以css3是不断的演进的,直到现在。

CSS逐步普及,但是精确控制css3的动画,还是非常麻烦。

复杂web动画,不慌,选择 web Animations API 》,比如直播的世界消息或者弹幕:

我们需要消息先运动到屏幕中间,消息最少需要在停留2秒,如果消息过长,消息还需要 匀速滚动 ,之后再滑出屏幕。

  1. 滑入

  2. 暂停,如果消息过长,消息还需要匀速滚动

  3. 滑出

难点就在于,暂停阶段,消息滚动的时间并不是确定的,需要计算。 这个时候,纯CSS3的动画,难度就有些高了,采用 Web Animations API,天然的和JS亲和,那就简单多了。

2013年,W3C 提出 Web Animation API(简称 WAAPI)工作草案,但是知道如今(截止2024年1月)还是草案状态(十年磨一剑——CSS3又何尝不是如此!)。但是目前chrome基本都支持!

具体可以MDN例子:https://developer.mozilla.org/zh-CN/docs/Web/API/Element/animate

这里不在赘述,但是只是为了滚动条滚动,用这个api 是大材小用哈!

转载本站文章《操作滚动条小结:scrollIntoView/animate等方法的来龙去脉》,
请注明出处:https://www.zhoulujun.cn/html/webfront/SGML/htmlBase/2022_1223_9017.html

操作滚动条小结:scrollIntoView/animate等方法的来龙去脉的更多相关文章

  1. webdriver-js操作滚动条

    webdriver-js操作滚动条 1.      webdriver高级应用-js操作滚动条 1.滑动页面的滚动条到页面最下面 2.滑动页面的滚动条到页面的某个元素 3.滑动页面的滚动条向下移动某个 ...

  2. selenium操作滚动条的几种方式

    1.操作滚动条到当前可见视图的元素位置 WebElement element = dr.findElement(By.id("4")); ((JavascriptExecutor) ...

  3. java使用dom4j和XPath解析XML与.net 操作XML小结

    最近研究java的dom4j包,使用 dom4j包来操作了xml 文件 包括三个文件:studentInfo.xml(待解析的xml文件), Dom4jReadExmple.java(解析的主要类), ...

  4. selenium——操作滚动条

    在自动化测试的过程中,难免会应用到翻页键,但是webdriver提供的方法都是操作当前页面可见的元素,对于未在当前范围展示的翻页键,该如何操作呢? 小编在这里介绍一种方法:使用JavaScript操作 ...

  5. jQuery---jq操作标签文本(html(),text()),jq操作文档标签(插入,删除,修改),克隆,,jq操作属性,jq操作class属性,jq操作表单value,jq操作css,jq操作盒子(重要),jq操作滚动条

    jQuery---jq操作标签文本(html(),text()),jq操作文档标签(插入,删除,修改),克隆,,jq操作属性,jq操作class属性,jq操作表单value,jq操作css,jq操作盒 ...

  6. jQuery操作Table tr td常用的方法

    虽然现在DIV+CSS进行页的布局大行其道,但是很多地方使用table还是有很多优势,用table展示数据是比较方便的,下面汇总了jQuery操作Table tr td常用的方法,熟记这些操作技巧,下 ...

  7. 一对一关联查询时使用relation连贯操作查询后,调用getLastSql()方法输出的sql语句

    如题: 一对一关联查询时使用relation连贯操作查询后,调用getLastSql()方法输出的sql语句不是一条关联查询语句. 例如: $list = $db->relation(true) ...

  8. 编写高质量代码改善C#程序的157个建议[正确操作字符串、使用默认转型方法、却别对待强制转换与as和is]

    前言 本文主要来学习记录前三个建议. 建议1.正确操作字符串 建议2.使用默认转型方法 建议3.区别对待强制转换与as和is 其中有很多需要理解的东西,有些地方可能理解的不太到位,还望指正. 建议1. ...

  9. sqlite:多线程操作数据库“database is locked”解决方法(二)

    上一篇博客<sqlite:多线程操作数据库“database is locked”解决方法>通过注册延时函数的方法来处理数据库被锁的问题.此方法固然能解决问题,但是在多个线程向数据库写入大 ...

  10. JS前端开发判断是否是手机端并跳转操作(小结)

    JS前端开发判断是否是手机端并跳转操作(小结) 这篇文章主要介绍了JS前端开发判断是否是手机端并跳转操作,非常不错,具有参考借鉴价值,需要的朋友可以参考下 常用跳转代码 ? 1 2 3 4 5 6 7 ...

随机推荐

  1. inventory 主机清单

    inventory 主机清单 //Inventory支持对主机进行分组,每个组内可以定义多个主机,每个主机都可以定义在任何一个或多个主机组内. //如果是名称类似的主机,可以使用列表的方式标识各个主机 ...

  2. 彻底搞懂CAP理论(电商系统)

    1.理解CAP CAP是 Consistency.Availability.Partition tolerance三个词语的缩写,分别表示一致性.可用性.分区容忍性. 下边我们分别来解释: 为了方便对 ...

  3. 【scipy 基础】--图像处理

    SciPy库本身是针对科学计算而不是图像处理的,只是图像处理也包含了很多数学计算,所以Scipy也提供了一个专门的模块ndimage用于图像处理. ndimage模块提供的功能包括输入/输出图像.显示 ...

  4. 【免费】小傅哥 DDD 开发小册

    作者:小傅哥 博客:https://bugstack.cn 沉淀.分享.成长,让自己和他人都能有所收获! 大家好,我是技术UP主小傅哥. 如果在面试的时候,面试官问你DDD是什么,你怎么解释?是不是感 ...

  5. vue+element-ui小笔记

    1.图片加载失败,给默认图 2.form表单中,输入框加回车事件,页面刷新,如何解决? 3.使用在线主题生成工具,修改element自定义主题色 1.图片加载失败,给默认图,两种解决方法: 方法一: ...

  6. MySQL 有哪些常见的面试题

    MySQL 是一种常用的关系型数据库管理系统,在面试过程中经常会涉及与 MySQL 相关的问题.以下是一些常见的 MySQL 面试题: 1. 介绍一下 MySQL 和其他数据库管理系统的区别. - M ...

  7. VS Code安装教程

    一.下载 1.官网 下载地址:https://code.visualstudio.com/Download 2.下载 根据自己电脑型号下载,此处以Windows为例. 二.安装 1.下载完成后,直接点 ...

  8. MDI窗体,打开子窗口的时候关闭其他子窗口及去除MainMenuStrip上自动产生的图标

    去除MDI子窗体最大化后在MainMenuStrip上自动产生的图标和最大化.最小化以及关闭按钮在MainMenuStrip的ItemAdded事件中添加代码如下: 1 private void me ...

  9. 使用mumu模拟器抓包 andriod app

    背景 公司H5嵌入到农行手机app里面.某天有人反馈进入国内机票订单详情时,应用崩溃了,如下图: 经过测试,此问题仅在安卓手机中出现,且其他页面都正常.于是我怀疑可能是这个页面代码有问题,想着能否抓包 ...

  10. maven 配置(cmd 黑窗口执行 mvn 时默认的 settings 文件和 idea maven 相关配置)

    写在前面: 本文章用于记录博主平时遇到的问题,步骤略粗糙,目的在于记录一边后续博主自己查找,如果能帮助到其他人更好.文章中用到的链接均为自行引入,侵删,谢谢(2I2Rc*@JY8) 问题说明:在一次使 ...