Vue金融数字格式化(并保留小数)数字滚动效果实现

 更新时间:2023年04月20日 09:38:52   作者:前端 晓雷  
这篇文章主要介绍了Vue金融数字格式化(并保留小数) 数字滚动效果,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

Vue金融数字格式化(并保留小数) 数字滚动

 提示

 我选用的是Vue 过滤器使用,个人觉得比较方便,不过过滤器不支持Vue3,你可以封装成方法嘛都行,下面我以过滤器的形式展示出来

  filters: {
    // 截取字符串
    subStringText(value, index) {
      const str = String(value);
      if (!value) return 0;
      return str.length > index ? str.substring(0, index) + '...' : str;
    },
   // 格式化数字
    formatNumber(num,decimals) {
      num = num.toFixed(decimals);
      num += '';
      const x = num.split('.');
      let x1 = x[0];
      const x2 = x.length > 1 ? '.' + x[1] : '';
      const rgx = /(\d+)(\d{3})/;
      if (',' && isNaN(parseFloat(','))) {
        while (rgx.test(x1)) {
          x1 = x1.replace(rgx, '$1' + ',' + '$2');
        }
      }
      return  x1 + x2;
    },
  },

使用: 

有个插件 --  可以轻松实现数字滚动并且数字格式化,推荐vue-count-to ,非常友好,

补充:vue做数字滚动效果

vue实现数字滚动效果

近期在做项目的时候,产品要求实现数字滚动效果如下:

在这里插入图片描述

用jquery实现

html:
<div class="develop">
<!--滚动的数字-->
        <p><span class="shuzi">3000000</span></p>
        <p><span class="shuzi">60000</span></p>
    </div>
js:
$(".navigation_right li").click(function () {
    $(this).siblings('li').removeClass("yanse");
  });
  let arr = $(".develop>p>.shuzi");
  arr.each(function(e, a){
    let num = $(a).text()
    let i = 0;
    let count = parseInt(num /500);
    let timer = setInterval(function(){
      $(a).text(i)
      i += count;
      if (i > num)
        window.clearInterval(timer)
    }, 5)
  })

这样做有一个问题,只能和500取余且为整数,而且滚动的时间也没发控制,显然是不满足我们的业务场景的。

用vue-countTo实现

vue-countTo是一个无依赖,轻量级的vue组件,可以自行覆盖easingFn。

安装使用

npm install vue-count-to

例子

<template>
  <countTo :startVal='startVal' :endVal='endVal' :duration='3000'></countTo>
</template>
<script>
//直接引入组件'vue-count-to'
  import countTo from 'vue-count-to';
  export default {
  //注册组件
    components: { countTo },
    data () {
      return {
      //数字开始
        startVal: 0,
       //数字结束
        endVal: 50000
      }
    }
  }
</script>

其中:startVal为开始数字,startVal为结束数字,duration为滚动时长, decimal:保留小数点后几位

PropertyDescriptiontypedefault
startVal开始值Number0
endVal结束值Number2017
duration持续时间,以毫秒为单位Number3000
autoplay自动播放Booleantrue
decimals要显示的小数位数Number0
decimal十进制分割String.
separator分隔符String,
prefix前缀String''
suffix后缀String''
useEasing使用缓和功能Booleantrue
easingFn缓和回调Function

** 注意:当autoplay:true时,它将在startVal或endVal更改时自动启动**

Function NameDescription
mountedCallback挂载以后返回回调
start开始计数
pause暂停计数
reset

重置countTo

到此这篇关于Vue金融数字格式化(并保留小数) 数字滚动的文章就介绍到这了,更多相关vue数字滚动内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 微信内置开发 iOS修改键盘换行为搜索的解决方案

    微信内置开发 iOS修改键盘换行为搜索的解决方案

    今天小编就为大家分享一篇微信内置开发 iOS修改键盘换行为搜索的解决方案,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-11-11
  • Vue 详解mixins混入用法大全

    Vue 详解mixins混入用法大全

    如果我们在每个组件中去重复定义这些属性和方法会使得项目出现代码冗余并提高了维护难度,针对这种情况官方提供了Mixins特性,这时使用Vue mixins混入有很大好处,下面就介绍下Vue mixins混入使用方法,需要的朋友参考下吧
    2021-08-08
  • vue项目配置国际化$t('')的介绍和用法示例

    vue项目配置国际化$t('')的介绍和用法示例

    这篇文章主要给大家介绍了关于vue项目配置国际化 $t('')的介绍和用法的相关资料,多语言和国际化现在已经成为一个网站或应用的必要功能之一,Vue作为一款流行的前端框架,在这方面也有着灵活的解决方案,需要的朋友可以参考下
    2023-09-09
  • vuejs2.0实现一个简单的分页示例

    vuejs2.0实现一个简单的分页示例

    本篇文章主要介绍了vuejs2.0实现一个简单的分页示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-02-02
  • vue实现翻牌动画

    vue实现翻牌动画

    这篇文章主要为大家详细介绍了vue实现翻牌动画,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-04-04
  • vue学习笔记之vue1.0和vue2.0的区别介绍

    vue学习笔记之vue1.0和vue2.0的区别介绍

    今天我们来说一说vue1.0和vue2.0的主要变化有哪些?对vue相关知识感兴趣的朋友一起学习吧
    2017-05-05
  • vue如何实现本项目页面之间跳转

    vue如何实现本项目页面之间跳转

    这篇文章主要介绍了vue如何实现本项目页面之间跳转,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-04-04
  • Vue导航守卫使用教程详解

    Vue导航守卫使用教程详解

    这篇文章主要介绍了Vue导航守卫使用教程,可以向任意给定的导航守卫传递next,但是next的使用过程容易出错,需要确保next在任何给定的导航守卫中都被严格调用一次
    2023-04-04
  • Vue使用mockjs问题(返回数据、get、post 请求)

    Vue使用mockjs问题(返回数据、get、post 请求)

    这篇文章主要介绍了Vue使用mockjs问题(返回数据、get、post 请求),具有很好的参考价值,希望对大家有所帮助。
    2023-05-05
  • vue在data中定义变量后依旧报undefined的解决

    vue在data中定义变量后依旧报undefined的解决

    这篇文章主要介绍了vue在data中定义变量后依旧报undefined的解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03

最新评论