奋斗30天Javascript之scrollTo和scrollBy两个JS API(Part31)

一、韩信么?

scrollTo和scrollBy这两个JS API也是用来控制元素或者窗体的滚动距离的。

我脑中的存储快速索引了一遍,发现JS API中控制元素或者窗体的滚动距离的API还真不少。

例如兼容性很好的scrollLeft和scrollTop,使用示意:

// 设置element左滚动距离100
element.scrollLeft = 100;
// 设置element上滚动距离200
element.scrollTop = 200;

或者IE9+浏览器支持,控制窗体滚动距离的pageXOffset和pageYOffset(注意,X, Y在Offset的前面):

// 设置窗体左滚动距离100
window.pageXOffset = 100;
// 设置窗体上滚动距离200
window.pageYOffset = 200;

结果现在又多了个IE/Edge浏览器不支持的scrollTo和scrollBy两个JS API。

滚动是韩信吗?走多多益善的套路?

二、文体两开花

scrollTo和scrollBy两个JS API是近亲,语法一模一样,作用也非常类似。

这两个API都是文体两开花,既能作用于windows对象,表示窗体滚动;又可以作用于普通Element元素,表示元素滚动。

示意:

window.scrollTo();
Element.scrollTo();

window.scrollBy();
Element.scrollBy();

但是这两个API控制滚动的细节有所出入。

scrollTo()表示滚到到指定的位置,而scrollBy()表示相对当前的位置滚动多少距离。

例如:

window.scrollTo(100, 200);

上面的写法等同于:

// 设置窗体左滚动距离100
window.pageXOffset = 100;
// 设置窗体上滚动距离200
window.pageYOffset = 200;

而:

window.scrollBy(10, 20);   // 偏移10, 20滚动距离

上面的写法等同于:

// 设置窗体左滚动距离增加10
window.pageXOffset += 10;
// 设置窗体上滚动距离增加20
window.pageYOffset += 20;

具体语法

element.scrollTo(x-coord, y-coord)
element.scrollTo(options)

element.scrollBy(x-coord, y-coord)
element.scrollBy(options)

其中

x-coord

X坐标。表示距离左侧滚动的距离坐标大小。

y-coord

y坐标。表示距离左侧滚动的距离坐标大小。

options

options是一个ScrollToOptions参数类型,包含lefttopbehavior这3个参数值。例如:

window.scrollBy({
  top: 10,
  left: 20,
  behavior: 'smooth'
});

具体:

  • left 指定沿着X轴距离window或者element滚动距离,值的单位是像素。
  • top 指定沿着Y轴距离window或者element的滚动距离,值的单位是像素。
  • behavior 指定滚动触发的时候,是平滑的动画还是直接过去。关于平滑滚动,可以参考去年写的这篇关于CSS scroll-behavior的文章

也就是window.scrollBy(10, 20)我们也可以写作:

window.scrollBy({
  left: 10,
  top: 20
})

HTML代码如下:

<button onclick="window.scrollBy(0, 20)">点击我滚动+20</button>

三、优缺点

scrollTo和scrollBy两个JS API的优点有两个:

  1. 调用统一
    scrollLeft/scrollTop这两个属性只能作为元素上,在window对象上没有效果。而pageXOffset/pageYOffset只能作用于window对象上,在元素上没有效果。而scrollTo和scrollBy不仅可以作用于window对象上,还可以作用于元素上。实现的调用的统一。
  2. 平滑支持
    scrollLeft/scrollTop和pageXOffset/pageYOffset控制滚动定位,想要定位平滑,只能借助于CSS scroll-behavior属性,JS这块设置无力。但是scrollTo和scrollBy在比较方便,直接有API参数支持。

scrollTo和scrollBy两个JS API的缺点就一个:

scrollTo和scrollBy两个JS API在IE浏览器中是无效的,如果是需要兼容IE浏览器的项目,需要先写个简单的polyfill(见文末)。

  1. 兼容性

四、狐朋狗友们

滚动相关的这波API不仅仅有scrollTo和scrollBy,还有scroll,使用示意:

Window.scroll()
Element.scroll()

scroll()方法和scrollTo()语法和作用是一样的。


另外还有两个非标准的相对滚动方法(目前仅Firefox浏览器支持),如下:

  • Window.scrollByLines()

    表示相对当前的滚动位置再滚动指定行数距离,行为表现接近于上下键控制滚动。语法如下:

    window.scrollByLines(lines)

    例如window.scrollByLines(-5)表示向上滚动5行的距离。

  • Window.scrollByPages()

    表示相对当前的滚动位置再滚动指定页数距离,行为表现接近于空格键(反向+Shift)控制滚动。语法如下:

    window.scrollByPages(pages)

    例如window.scrollByPages(-1);表示向上滚动1页的距离。

五、还算有点用

一番整理下来,scrollTo和scrollBy这两个API还算有点用。以后元素的滚动距离控制我打算都使用这两个API了,至于原因,不用用怎么知道这两个API隐藏的坑或者埋的彩蛋呢。

反正得失差不多,用用新的API,增加点前端技术的广度,挺好!

IE的polyfill其实很简单,顺手写两个:

/**
 * @description scrollTo/scrollBy的polyfill,IE9+
 * @author zhangxinxu(.com)
 * @created 2019-07-27
 */

if (!window.scrollTo) {
    window.scrollTo = function (x, y) {
        window.pageXOffset = x;
        window.pageYOffset = y;
    };
}
if (!window.scrollBy) {
    window.scrollBy = function (x, y) {
        window.pageXOffset += x;
        window.pageYOffset += y;
    };
}
if (!document.body.scrollTo) {
    Element.prototype.scrollTo = function (x, y) {
        this.scrollLeft = x;
        this.scrollTop = y;
    };
}
if (!document.body.scrollBy) {
    Element.prototype.scrollBy = function (x, y) {
        this.scrollLeft += x;
        this.scrollTop += y;
    };
}

或者点击这里下载scroll-polyfill.js

转自《还算有点用的scrollTo和scrollBy两个JS API

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值