Home Web Front-end HTML Tutorial How to implement the progress bar function of h5 timer

How to implement the progress bar function of h5 timer

Jan 19, 2018 am 09:13 AM
html5 Function timer

This time I will bring you h5's timer How to implement the progress bar function, what are the precautions for h5's timer to implement the progress bar function , the following is a practical case, let’s take a look.

Before requestAnimationFrame appeared, we generally used setTimeout and setInterval. So why did html5 add a new requestAnimationFrame? What problem did it appear to solve?

Advantages and features:

1) requestAnimationFrame will concentrate all DOM operations in each frame, complete it in one redraw or reflow, and reflow The time interval between drawing or reflowing closely follows the refresh frequency of the browser

2) In hidden or invisible elements, requestAnimationFrame will not be redrawn or reflowed, which of course means less CPU , GPU and memory usage

3) requestAnimationFrame is an API provided by the browser specifically for animation. The browser will automatically optimize the method call at runtime, and if the page is not active, the animation will automatically Pause, effectively saving CPU overhead

In one sentence: this thing has high performance, will not freeze the screen, and automatically adjusts the frame rate according to different browsers. If you don’t understand it or don’t understand it, it doesn’t matter. This thing is related to the browser rendering principle. Let’s learn to use it first!

How to use requestAnimationFrame?

The usage method is similar to the timer setTimeout. The difference is that it does not need to set the time interval parameter

var timer = requestAnimationFrame( function(){
       console.log( '定时器代码' );
   } );
Copy after login

The parameter is a callback function, and the return value is an integer , used to represent the number of the timer.

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <script>
        window.onload = function(){
            var aInput = document.querySelectorAll( "input" ),
                timer = null;
            aInput[0].onclick = function(){
                timer = requestAnimationFrame( function say(){
                    console.log( 1 );
                    timer = requestAnimationFrame( say );
                } );
            };
            aInput[1].onclick = function(){
                cancelAnimationFrame( timer );
            }
        }
    </script>
</head>
<body>
    <input type="button" value="开启">
    <input type="button" value="关闭">
</body>
</html>
Copy after login

cancelAnimationFrame is used to close the timer

This method needs to handle compatibility:

Simple compatibility:

window.requestAnimFrame = (function(){
  return  window.requestAnimationFrame       ||
          window.webkitRequestAnimationFrame ||
          window.mozRequestAnimationFrame    ||
          function( callback ){
            window.setTimeout(callback, 1000 / 60);
          };
})();
Copy after login

If the browser does not recognize AnimationFrame, use setTimeout for compatibility.

Use three different timers (setTimeout, setInterval, requestAnimationFrame) to implement the loading of a progress bar

I believe I have read these You have mastered the case method. For more exciting information, please pay attention to other related articles on the PHP Chinese website!

Related reading:

How to implement table mouse drag sorting in HTML

How to use the new features of HTML 5

How to solve various ie6-ie10 compatibility issues

The above is the detailed content of How to implement the progress bar function of h5 timer. 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 AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

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)

Table Border in HTML Table Border in HTML Sep 04, 2024 pm 04:49 PM

Guide to Table Border in HTML. Here we discuss multiple ways for defining table-border with examples of the Table Border in HTML.

Nested Table in HTML Nested Table in HTML Sep 04, 2024 pm 04:49 PM

This is a guide to Nested Table in HTML. Here we discuss how to create a table within the table along with the respective examples.

HTML margin-left HTML margin-left Sep 04, 2024 pm 04:48 PM

Guide to HTML margin-left. Here we discuss a brief overview on HTML margin-left and its Examples along with its Code Implementation.

HTML Table Layout HTML Table Layout Sep 04, 2024 pm 04:54 PM

Guide to HTML Table Layout. Here we discuss the Values of HTML Table Layout along with the examples and outputs n detail.

HTML Input Placeholder HTML Input Placeholder Sep 04, 2024 pm 04:54 PM

Guide to HTML Input Placeholder. Here we discuss the Examples of HTML Input Placeholder along with the codes and outputs.

HTML Ordered List HTML Ordered List Sep 04, 2024 pm 04:43 PM

Guide to the HTML Ordered List. Here we also discuss introduction of HTML Ordered list and types along with their example respectively

Moving Text in HTML Moving Text in HTML Sep 04, 2024 pm 04:45 PM

Guide to Moving Text in HTML. Here we discuss an introduction, how marquee tag work with syntax and examples to implement.

HTML onclick Button HTML onclick Button Sep 04, 2024 pm 04:49 PM

Guide to HTML onclick Button. Here we discuss their introduction, working, examples and onclick Event in various events respectively.

See all articles