当前位置: 移动技术网 > IT编程>脚本编程>vue.js > vue数字类型过滤器的示例代码

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

2017年12月12日  | 移动技术网IT编程  | 我要评论

多梦网络,狂蟒天下,中国驴盟

需求 只能输入数字

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

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

效果图


可以使用在普通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>

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

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网