# CountUp 数字滚动
### 介绍
数字滚动组件,用于数字的动态效果展示
### 安装
``` javascript
import { createApp } from 'vue';
// vue
import { CountUp } from '@nutui/nutui';
// taro
import { CountUp } from '@nutui/nutui-taro';
const app = createApp();
app.use(CountUp);
```
## 代码演示
## 基本用法
```html
```
## 数字滚动
```html
```
## 自定义数字图片展示
```html
```
```javascript
export default {
data() {
return {
customNumber: 618,
bgImage: 'https://img10.360buyimg.com/imagetools/jfs/t1/133024/3/2251/2646/5ee7549aE8dc02d7e/de6901b6c72db396.png'
};
},
methods: {
run() {
let timer = null;
timer = setInterval(() => {
this.customNumber = Math.floor(Math.random() * (700 - 100 + 1) + 100);
}, 5000);
}
},
mounted() {
this.run();
}
};
```
## 抽奖
```html
抽奖
```
```javascript
export default {
data() {
return {
startFlag: false,
machineNum: 3,
bgImage: 'https://img10.360buyimg.com/imagetools/jfs/t1/121466/20/6784/28830/5f06e7f2Edbb8998c/9bdd9e7b24dff9fe.png',
prizeLevel: 0
};
},
methods: {
startRole() {
this.prizeLevel = Math.floor(Math.random() * 5 + 1);
this.startFlag = true;
this.$refs['countup-machine'].machineLuck();
},
scrollAniEnd() {
this.$toast.text('恭喜中奖!!!');
setTimeout(() => {
this.startFlag = false;
}, 300);
}
}
};
```
## Prop
| 字段 | 说明 | 类型 | 默认值
|----- | ----- | ----- | -----
| init-num | 初始数字 | Number | 0
| end-num | 结束数字 | Number | 0
| speed | 间隔数字,目前仅支持基本用法 | Number | 1
| to-fixed | 保留小数点后几位 | Number | 以传入的数字为准
| start-flag | 触发数字滚动的标识 | Boolean | true
| during | 滚动一次运行时间 | Number | 1000
| num-width | 数字宽度,常用于自定义无缝滚动 | Number | 20
| num-height | 数字高度,常用于自定义无缝滚动(抽奖功能必传) | Number | 20
| scrolling | 用于数字滚动展示 | Boolean | false
| custom | 用于自定义图片数字滚动 | Boolean | false
| custom-change-num | 要变化的数字(用于自定义图片,initNum\endNum在此无效) | Number | 1
| custom-bg-img | 自定义图片(建议使用雪碧图实现,使用抽奖功能必须使用雪碧图) | - | -
| custom-spac-num | 图片中数字之间可能会存在间距 | Number | 0
| type | 使用抽奖功能必传“machine” | string | ''
| machine-prize-num | 奖品个数,一共多少个奖品,必传 | number | 4
| machine-num | 抽奖位,即滚动几个,必传 | number | 3
| machine-prize-level | 中奖图标,图标在雪碧图中的位置 | number | 0
| machine-trun-more | 滚动圈数 | number | 0
> 说明:抽奖功能需要结合图标位置计算,故需传入雪碧图中单个图标的高度 num-height;中奖奖品根据雪碧图中的奖品位数来定位,从 1 到 N;
## Event
| 字段 | 说明 | 回调参数
|----- | ----- | -----
| scroll-end | 滚动结束后回调函数 | -