js中使用

js代码

const digitsRE = /(\d{3})(?=\d)/g

function currency (value, currency, decimals) {
  value = parseFloat(value)
  if (!isFinite(value) || (!value && value !== 0)) return ''
  currency = currency != null ? currency : '$'
  decimals = decimals != null ? decimals : 2
  var stringified = Math.abs(value).toFixed(decimals)
  var _int = decimals
    ? stringified.slice(0, -1 - decimals)
    : stringified
  var i = _int.length % 3
  var head = i > 0
    ? (_int.slice(0, i) + (_int.length > 3 ? ',' : ''))
    : ''
  var _float = decimals
    ? stringified.slice(-1 - decimals)
    : ''
  var sign = value < 0 ? '-' : ''
  return sign + currency + head +
    _int.slice(i).replace(digitsRE, '$1,') +
    _float
}

使用方法:将 1000000 转换为 $1,000,000.000

currency(1000000,'$',3)  //$1,000,000.000

这里写图片描述

vue中实现

创建 currency.js 文件,比之前的js代码多了一个 export

const digitsRE = /(\d{3})(?=\d)/g

export function currency (value, currency, decimals) {
  value = parseFloat(value)
  if (!isFinite(value) || (!value && value !== 0)) return ''
  currency = currency != null ? currency : '$'
  decimals = decimals != null ? decimals : 2
  var stringified = Math.abs(value).toFixed(decimals)
  var _int = decimals
    ? stringified.slice(0, -1 - decimals)
    : stringified
  var i = _int.length % 3
  var head = i > 0
    ? (_int.slice(0, i) + (_int.length > 3 ? ',' : ''))
    : ''
  var _float = decimals
    ? stringified.slice(-1 - decimals)
    : ''
  var sign = value < 0 ? '-' : ''
  return sign + currency + head +
    _int.slice(i).replace(digitsRE, '$1,') +
    _float
}

这里写图片描述

局部实现方式

引入 currency.js 文件

在要使用的组件中 import
import { currency } from './../util/currency' 
由于 函数currency 是通过 export 导出的,所以这里的 currency 必须使用 {} 包起来;
这里的 ./../util/currency 根据项目实际情况填写 currency.js 对应的路径

这里写图片描述
将 currency 加入到 filters

filters:{
    currency: currency
}

这里写图片描述
在vue组件中使用

{{ totalPrice | currency('$') }}

这里写图片描述
最终显示的结果
这里写图片描述

全局过滤器

找到我们的入口文件 main.js
这里写图片描述
在 main.js 中引入 currency.js 文件

在要使用的组件中 import
import { currency } from './util/currency' 
由于 函数currency 是通过 export 导出的,所以这里的 currency 必须使用 {} 包起来;
这里的 ./util/currency 根据项目实际情况填写 currency.js 对应的路径

在 main.js 中加入filter过滤器中

Vue.filter("currency",currency);

这里写图片描述
在vue组件中使用

{{ totalPrice | currency('$') }}

这里写图片描述
最终显示的结果
这里写图片描述

成长路上的一些知识分享,如有错误,欢迎指正批评!O(∩_∩)O

Logo

前往低代码交流专区

更多推荐