Table of Contents
Summary :
Usage method
Home Web Front-end JS Tutorial Native JS encapsulates the vertical scrolling animation tool function based on window.scrollTo()

Native JS encapsulates the vertical scrolling animation tool function based on window.scrollTo()

Jul 07, 2018 pm 05:43 PM
javascript

This article mainly introduces the vertical scrolling animation tool function encapsulated in native JS based on window.scrollTo(). It has a certain reference value. Now I share it with you. Friends in need can refer to it

Summary :

Native JS encapsulates the vertical scrolling animation tool function based on window.scrollTo(), which can be used for operations such as anchor positioning and returning to the top.

Reason for encapsulation:
In the vue project, when encountering the need to achieve a vertical scrolling effect, there are two initial methods that come to mind:
1: Use the window.scrollTo() method, but this The method has no animation effect and needs to be encapsulated manually.
2: Using JQuery’s animation function has obvious disadvantages: JQuery needs to be introduced.
Obviously, choosing the first option is much better.

The following is the method scroll() that encapsulates window.scrollTo(). The file name is scroll.js

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

// Created by xiaoqiang on 30/05/2018.

/**

 * @param {numeber} currentY 需要移动的dom当前位置离网页顶端的距离

 * @param {number} targetY 需要移动的dom当前位置离要移到的位置的距离

 */

function scroll (currentY, targetY) {

  // 计算需要移动的距离

  let needScrollTop = targetY - currentY

  let _currentY = currentY

  setTimeout(() => {

    // 一次调用滑动帧数,每次调用会不一样

    const dist = Math.ceil(needScrollTop / 10)

    _currentY += dist

    window.scrollTo(_currentY, currentY)

    // 如果移动幅度小于十个像素,直接移动,否则递归调用,实现动画效果

    if (needScrollTop > 10 || needScrollTop < -10) {

      scroll(_currentY, targetY)

    else {

      window.scrollTo(_currentY, targetY)

    }

  }, 1)

}

// 暴露此方法

export default scroll

Copy after login
Usage method

For example, in vue, you can use it like this:
import scroll form '@/common/util/scroll.js'
Then scroll() is called in the function that responds to the trigger event, and two parameters need to be passed in, for example:

1

2

3

4

5

6

7

      methods: {

        test () {

          const scrollHeight = document.getElementsByClassName('scroll-element')[0].offsetTop

          const currentY = document.documentElement.scrollTop || document.body.scrollTop

          scroll(currentY, scrollHeight)

        }

      }

Copy after login

Yes Feel free to point out errors or unclear areas or areas that can be improved. O(∩_∩)O~~

The above is the entire content of this article. I hope it will be helpful to everyone’s study. More related content Please pay attention to PHP Chinese website!

Related recommendations:

JS implements merge sorting

vue implements digital scrolling increasing effect

Jquery adds loading transition mask

The above is the detailed content of Native JS encapsulates the vertical scrolling animation tool function based on window.scrollTo(). For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot Article Tags

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to implement an online speech recognition system using WebSocket and JavaScript How to implement an online speech recognition system using WebSocket and JavaScript Dec 17, 2023 pm 02:54 PM

How to implement an online speech recognition system using WebSocket and JavaScript

WebSocket and JavaScript: key technologies for implementing real-time monitoring systems WebSocket and JavaScript: key technologies for implementing real-time monitoring systems Dec 17, 2023 pm 05:30 PM

WebSocket and JavaScript: key technologies for implementing real-time monitoring systems

How to implement an online reservation system using WebSocket and JavaScript How to implement an online reservation system using WebSocket and JavaScript Dec 17, 2023 am 09:39 AM

How to implement an online reservation system using WebSocket and JavaScript

How to use JavaScript and WebSocket to implement a real-time online ordering system How to use JavaScript and WebSocket to implement a real-time online ordering system Dec 17, 2023 pm 12:09 PM

How to use JavaScript and WebSocket to implement a real-time online ordering system

Simple JavaScript Tutorial: How to Get HTTP Status Code Simple JavaScript Tutorial: How to Get HTTP Status Code Jan 05, 2024 pm 06:08 PM

Simple JavaScript Tutorial: How to Get HTTP Status Code

JavaScript and WebSocket: Building an efficient real-time weather forecasting system JavaScript and WebSocket: Building an efficient real-time weather forecasting system Dec 17, 2023 pm 05:13 PM

JavaScript and WebSocket: Building an efficient real-time weather forecasting system

How to get HTTP status code in JavaScript the easy way How to get HTTP status code in JavaScript the easy way Jan 05, 2024 pm 01:37 PM

How to get HTTP status code in JavaScript the easy way

How to use insertBefore in javascript How to use insertBefore in javascript Nov 24, 2023 am 11:56 AM

How to use insertBefore in javascript

See all articles