欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

vue数字类型过滤器的示例代码

程序员文章站 2022-05-14 19:03:20
需求 只能输入数字 输入字母和特殊字符自动过滤掉 输入完成失焦自动加.00 如果输入了小数自动四舍五入为22.22类似这样格式 效果图 可以使用...

需求 只能输入数字

输入字母和特殊字符自动过滤掉

输入完成失焦自动加.00 如果输入了小数自动四舍五入为22.22类似这样格式

效果图

vue数字类型过滤器的示例代码

可以使用在普通js和angular里面,vue 直接调用

先上调用的函数

/**
 * user: sheyude
 * date: 2017/9/4 0004
 * time: 上午 10:51
 *
 */
let number = {
  twoway: true,
    bind:function (el) {
  el.addeventlistener('blur',function () {
    // let value = formatnumber(el.value,2,0)
    let value

    (function(){
      value = formatnumber(el.value,2,0)
      return value
    })()
    el.value =value
  })
},
  update:function (el,binding,vnode) {
    if(el.value !== ''){
      el.value = el.value.replace(/[^0-9.]+/g, '');
    }
  }
}

/**
 * 将数值四舍五入后格式化.
 * @param num 数值(number或者string)
 * @param cent 要保留的小数位(number)
 * @param isthousand 是否需要千分位 0:不需要,1:需要(数值类型);
 * @return 格式的字符串,如'1,234,567.45'
 * @type string
 */
function formatnumber(num,cent,isthousand) {
  num = num.tostring().replace(/\$|\,/g,'');

  // 检查传入数值为数值类型
  if(isnan(num))
    num = "0";

  // 获取符号(正/负数)
  let sign = (num == (num = math.abs(num)));

  num = math.floor(num*math.pow(10,cent)+0.50000000001); // 把指定的小数位先转换成整数.多余的小数位四舍五入
  let cents = num%math.pow(10,cent);       // 求出小数位数值
  num = math.floor(num/math.pow(10,cent)).tostring();  // 求出整数位数值
  cents = cents.tostring();        // 把小数位转换成字符串,以便求小数位长度

  // 补足小数位到指定的位数
  while(cents.length<cent)
    cents = "0" + cents;

  if(isthousand) {
    // 对整数部分进行千分位格式化.
    for (var i = 0; i < math.floor((num.length-(1+i))/3); i++)
      num = num.substring(0,num.length-(4*i+3))+','+ num.substring(num.length-(4*i+3));
  }

  if (cent > 0)
    return (((sign)?'':'-') + num + '.' + cents);
  else
    return (((sign)?'':'-') + num);
}
export {
  number
}

如果你是vue用户用户请继续看 vue全局注册指令

/**
 * user: sheyude
 * date: 2017/9/4 0004
 * time: 上午 11:00
 *
 */
import {number} from './numberdirective'


import vue from 'vue'

vue.directive('numbers',number)

vue 使用方式 input 里面加入v-numbers就行

<template>
  <input type="text" class="form-control" placeholder="" v-numbers v-model="valuedata">
</template>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。