CountUp.js ialah kelas JavaScript yang ringan dan bebas pergantungan yang boleh digunakan untuk mencipta animasi dengan cepat yang memaparkan data berangka dengan cara yang lebih menarik. CountUp boleh mengira dalam kedua-dua arah, bergantung pada nilai mula dan akhir yang dilalui.
Walaupun terdapat banyak komponen Vue berdasarkan pengkapsulan sekunder countUp.js di pasaran, saya secara peribadi tidak suka menggunakan pengkapsulan pihak ketiga ini kerana sukar untuk menjamin kekerapan kemas kini komponen pihak ketiga . Mungkin pengarang saya hanya merangkum dan memuat naiknya secara sesuka hati, tanpa niat untuk terus mengekalkannya Jika digunakan, bermakna ia tidak akan dapat dikekalkan pada masa hadapan, jadi saya mengesyorkan untuk melaksanakan enkapsulasi sekunder ini. sendiri. Kita boleh membiasakannya melalui enkapsulasi ini vue3
, ts
Sintaks
Pasang pertama
npm i countup.js
Selepas pemasangan, buat fail baharu CountUp.vue
, bahagian templat sangat mudah, hanya satu teg span
diperlukan, dan pada masa yang sama Beri span
ref='countupRef'
dan selesai mula-mula perkenalkan countup.js
butang tetikus dan klik pada Countup.js untuk melihat fail d.ts countUp.d.ts
dieksport ke sini seperti berikut:
export interface CountUpOptions { startVal?: number; decimalPlaces?: number; duration?: number; useGrouping?: boolean; useIndianSeparators?: boolean; useEasing?: boolean; smartEasingThreshold?: number; smartEasingAmount?: number; separator?: string; decimal?: string; easingFn?: (t: number, b: number, c: number, d: number) => number; formattingFn?: (n: number) => string; prefix?: string; suffix?: string; numerals?: string[]; enableScrollSpy?: boolean; scrollSpyDelay?: number; scrollSpyOnce?: boolean; onCompleteCallback?: () => any; plugin?: CountUpPlugin; } export declare interface CountUpPlugin { render(elem: HTMLElement, formatted: string): void; } export declare class CountUp { private endVal; options?: CountUpOptions; version: string; private defaults; private rAF; private startTime; private remaining; private finalEndVal; private useEasing; private countDown; el: HTMLElement | HTMLInputElement; formattingFn: (num: number) => string; easingFn?: (t: number, b: number, c: number, d: number) => number; error: string; startVal: number; duration: number; paused: boolean; frameVal: number; once: boolean; constructor(target: string | HTMLElement | HTMLInputElement, endVal: number, options?: CountUpOptions); handleScroll(self: CountUp): void; /** * Smart easing works by breaking the animation into 2 parts, the second part being the * smartEasingAmount and first part being the total amount minus the smartEasingAmount. It works * by disabling easing for the first part and enabling it on the second part. It is used if * usingEasing is true and the total animation amount exceeds the smartEasingThreshold. */ private determineDirectionAndSmartEasing; start(callback?: (args?: any) => any): void; pauseResume(): void; reset(): void; update(newEndVal: string | number): void; count: (timestamp: number) => void; printValue(val: number): void; ensureNumber(n: any): boolean; validateValue(value: string | number): number; private resetDuration; formatNumber: (num: number) => string; easeOutExpo: (t: number, b: number, c: number, d: number) => number; }
Kelas CountUp
juga mempunyai antara muka CountUpOptions
daripada kelas CountUp
menerima tiga parameter, iaitu nod dom, endVal dan pilihan Kami menghantar tiga parameter ini sebagai constructor
Pada masa yang sama, berdasarkan nilai lalai, mula-mula dapatkan ref span sebagai bekas. dimulakan oleh props
, tentukan pembolehubah countUp
untuk menerima nilai pulangan numAnim
, , mulakan new CountUp(countupRef.value, props.end, props.options)
dalam onMounted
, dan kemudian kita boleh pergi Halaman memperkenalkan countUp.js
untuk melihat kesannya ialah nilai lalai, kami tidak perlu memasukkan mana-mana parameter Lihat sahaja pada masa ini, CountUp.vue
kod komponen adalah seperti berikut, CountUp.vue
<script setup lang="ts"> import { CountUp } from 'countup.js' import type { CountUpOptions } from 'countup.js' import { onMounted, ref } from 'vue' let numAnim = ref(null) as any const countupRef = ref() const props = defineProps({ end: { type: Number, default: 2023 }, options: { type: Object, default() { let options: CountUpOptions = { startVal: 0, // 开始的数字 一般设置0开始 decimalPlaces: 2, // number类型 小数位,整数自动添.00 duration: 2, // number类型 动画延迟秒数,默认值是2 useGrouping: true, // boolean类型 是否开启逗号,默认true(1,000)false(1000) useEasing: true, // booleanl类型 动画缓动效果(ease),默认true smartEasingThreshold: 500, // numberl类型 大于这个数值的值开启平滑缓动 smartEasingAmount: 300, // numberl类型 separator: ',',// string 类型 分割用的符号 decimal: '.', // string 类型 小数分割符合 prefix: '¥', // sttring 类型 数字开头添加固定字符 suffix: '元', // sttring类型 数字末尾添加固定字符 numerals: [] // Array类型 替换从0到9对应的字,也就是自定数字字符了,数组存储 } return options } } }) onMounted(() => { initCount() }) const initCount = () => { numAnim = new CountUp(countupRef.value, props.end, props.options) numAnim.start() } </script> <template> <span ref="countupRef"></span> </template>
dilaksanakan, jika nilai endVal kami berubah, memandangkan onMounted
CountUp.vue
telah selesai, ia tidak akan diubah suai secara serentak Jika nilai kami diperoleh secara tidak segerak, ia akan menyebabkan pemaparan yang kami mahu gagal. Hasilnya, maka kami perlu mendedahkan kaedah onMounted
ini dalam komponen kepada komponen induk Dalam vue3, kami hanya perlu menggunakan initCount
untuk mendedahkannya Pada masa yang sama, kami juga menambah baik prop kami dan mengesahkan Hadkan nilai defineExpose
masuk dan cuba elakkan ralat penggunaan Pada masa yang sama, ubah suai nilai lalai untuk mengelakkan beberapa masalah Kod akhir adalah seperti berikut optinos
<script setup lang="ts"> import { CountUp } from 'countup.js' import type { CountUpOptions } from 'countup.js' import { onMounted, ref } from 'vue' let numAnim = ref(null) as any const countupRef = ref() const props = defineProps({ end: { type: Number, default: 0 }, options: { type: Object, validator(option: Object) { let keys = ['startVal', 'decimalPlaces', 'duration', 'useGrouping', 'useEasing', 'smartEasingThreshold', 'smartEasingAmount', 'separator', 'decimal', 'prefix', 'suffix', 'numerals'] for (const key in option) { if (!keys.includes(key)) { console.error(" CountUp 传入的 options 值不符合 CountUpOptions") return false } } return true }, default() { let options: CountUpOptions = { startVal: 0, // 开始的数字 一般设置0开始 decimalPlaces: 2, // number类型 小数位,整数自动添.00 duration: 2, // number类型 动画延迟秒数,默认值是2 useGrouping: true, // boolean类型 是否开启逗号,默认true(1,000)false(1000) useEasing: true, // booleanl类型 动画缓动效果(ease),默认true smartEasingThreshold: 500, // numberl类型 大于这个数值的值开启平滑缓动 smartEasingAmount: 300, // numberl类型 separator: ',',// string 类型 分割用的符号 decimal: '.', // string 类型 小数分割符合 prefix: '', // sttring 类型 数字开头添加固定字符 suffix: '', // sttring类型 数字末尾添加固定字符 numerals: [] // Array类型 替换从0到9对应的字,也就是自定数字字符了,数组存储 } return options } } }) onMounted(() => { initCount() }) const initCount = () => { numAnim = new CountUp(countupRef.value, props.end, props.options) numAnim.start() } defineExpose({ initCount }) </script> <template> <span ref="countupRef"></span> </template> <style scoped lang='scss'></style>
Atas ialah kandungan terperinci Cara melaksanakan pemalam tatal digital dalam Vue3 berdasarkan countUp.js. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!