vue格式化输入框

/**
 *
 * @param {num} 格式化数数字保留2位
 * @param {max} 最大值
 * @param {min} 最小值
 * @param {isFen} 最大值是否是分单位
 * @param {returnMax} 超过最大值返回值
 * @return {*num}
 */

function changePrice(num, max = 1000000, min = 0, isFen = false, returnMax = 0, returnMin = 0) {
  const str =
      ('' + num)
        .replace(/[^d^.]+/g, '') // 1:把不是数字,不是小数点的过滤掉
        .replace(/^0+(d)/, '$1') // 2:第一位0开头,0后面为数字,则过滤掉,取后面的数字
        .replace(/^.+/, '0') // 3:如果输入的第一位为小数点,则替换成 0. 实现自动补全
        .replace(/^0+(d)/, '$1') // 4:第一位0开头,0后面为数字,则过滤掉,取后面的数字 防止 .0
        .match(/^d*(.?d{0,2})/g)[0] || '' // 5:最终匹配得到结果 以数字开头,只有一个小数点,而且小数点后面只能有0到2位小数
  const ns = str.replace(/.+$/, '')

  if (Number(ns) <= min) {
    return returnMin
  }
  if (Number(ns) > Number((max / 100).toFixed(2)) && isFen) {
    return returnMax
  }
  if (Number(ns) > Number((max).toFixed(2)) && !isFen) {
    return returnMax
  }
  return ns
}
function changeAmount(num, max = 1000000, min = 0, returnMax = 0, returnMin = 0) {
  const str = ('' + num) // 1:转成字符串
    .replace(/[^d]+/g, '') // 2:把不是数字的过滤掉
    .replace(/^.+(d)/, '$1') // 3
    .replace(/^0+(d)/, '$1') // 4:第一位0开头,0后面为数字,则过滤掉,取后面的数字
    .replace(/^.+/, '') // 5:如果输入的第一位为小数点,则替换成 = 实现自动补全
  if (Number(str) < min) {
    return returnMin
  }
  if (Number(str) > max) {
    return returnMax
  }
  return str
}
原文地址:https://www.cnblogs.com/ZeroShiro/p/15147680.html