react-scrollnumber

1.0.4 • Public • Published

react-scrollnumber

A digital scrolling component based on React. Contains the ordinary one-time scrolling effect, the linkage scrolling effect and the shaking effect.

Effect

The realization of statistics, let the numbers roll up.

Look

image

Install

  npm install --save-dev react-scrollnumber

or

  yarn add react-scrollnumber

Github Address

react-scrollnumber

Configuration

{  
  numAnimationConfig:Animation configuration parameters  
  linkage:Whether to enable linkage。After opening, only the 0th parameter configuration takes effect。  
  direction:direction  
  value:The value to scroll  
  increment:Effective when openLot is turned on, how many turns the front roll does not move  
  onAnimationEnd:Single digital animation execution end callback。  
  onAnimationAllEnd:All content execution end callback。  
  title:title  
  symbol:Digitally signed symbols  
  titleStyle:title style  
  openLot:Whether to turn on the number sign effect。  
  contentStyle:content style  
  height:Height, setting this height will affect the font size, the default is 30  
  style: style,   
  duration: Normal style execution time  
}  

Example

import React, { Component } from 'react'
import ReactDom from 'react-dom';
import ScrollNumber from 'react-scrollnumber';
const Example = () => {
   const animParams = [
       {
           animationDuration: 10,
           animationTimingFunction: 'linear',
           animationFillMode: 'forwards',
           animationIterationCount: 1,
           animationDelay: 0,
           value: 0
       },
       {
           animationDuration: 8,
           animationTimingFunction: 'linear',
           animationFillMode: 'forwards',
           animationIterationCount: 1,
           animationDelay: 0,
           value: 7
       },
       {
           animationDuration: 5,
           animationTimingFunction: 'linear',
           animationFillMode: 'forwards',
           animationIterationCount: 1,
           animationDelay: 0,
           value: 6
       }
   ];
   return (
       <div style={{
           width: '100%',
           textAlign: 'center',
           marginTop: '2em'
       }}>
           {/***Right To Left Linkage Style****/}
           <ScrollNumber
               numAnimationConfig={
                   {
                       animationDuration: 1000
                   }
               }
               linkage={true}
               direction={'right'}
               value={282204626}
               title='RightToLeftLinkage'
               titleStyle={{ textAlign: 'center' }}
               openLot={true}
               style={{
                   marginRight: '10%',
                   marginBottom: '10%'
               }}
               contentStyle={{
                   color: '#f35'
               }}
           />
           {/***Left To Right Linkage Style****/}
           <ScrollNumber
               numAnimationConfig={animParams}
               linkage={true}
               direction={'left'}
               value={282204626}
               title='LeftToRightLinkage'
               titleStyle={{ textAlign: 'center' }}
               openLot={true}
               style={{
                   marginRight: '10%',
                   marginBottom: '10%'
               }}
               contentStyle={{
                   color: '#7329d4'
               }}
           />
           {/***Left To Right Lot Style****/}
           <ScrollNumber
               // numAnimationConfig={}
               direction={'left'}
               value={282204626}
               increment={1}
               title='LeftToRightLot'
               titleStyle={{ textAlign: 'center' }}
               openLot={true}
               style={{
                   marginRight: '10%',
                   marginBottom: '10%'
               }}
               contentStyle={{
                   color: '#efc80a'
               }}
           />
           {/***Right To Left Lot Style****/}
           <ScrollNumber
               // numAnimationConfig={}
               direction={'right'}
               value={282204626}
               increment={1}
               title='RightToLeftLot'
               titleStyle={{ textAlign: 'center' }}
               openLot={true}
               style={{
                   marginRight: '10%',
                   marginBottom: '10%'
               }}
               contentStyle={{
                   color: '#ef0ad3'
               }}
           />
           {/***Normal Style****/}
           <ScrollNumber
               value={282204626}
               duration={5}
               onAnimationEnd={() => { console.log('End of execution') }}
               onAnimationAllEnd={() => { console.log('All execution ends') }}
               title='Normal'
               titleStyle={{ textAlign: 'center' }}
               style={{
                   marginRight: '10%',
                   marginBottom: '10%'
               }}
               contentStyle={{
                   color: '#0a90ef'
               }}
           />
           {/***Symbol Scrolling Style****/}
           <ScrollNumber
               value={282204626}
               symbol={
                   <span>*</span>
               }
               onAnimationEnd={() => { console.log('End of execution') }}
               onAnimationAllEnd={() => { console.log('All execution ends') }}
               title='SymbolScrolling'
               titleStyle={{ textAlign: 'center' }}
               style={{
                   marginRight: '10%',
                   marginBottom: '10%'
               }}
               contentStyle={{
                   color: '#2db52b'
               }}
               duration={10}
           />
       </div>
   )
}
 
ReactDom.render(
   <Example />,
   document.getElementById('root')
);

Package Sidebar

Install

npm i react-scrollnumber

Weekly Downloads

2

Version

1.0.4

License

ISC

Unpacked Size

28.8 kB

Total Files

7

Last publish

Collaborators

  • keen_pro