vue输入框保留小数位(v-decimalsNum指令)

问题描述

在平时开发中,经常会出现需要对输入框做保留小数位处理(原生type=number有坑),在当前输入框使用@change、@blur、@input等事件或者干脆用watch监听处理保留小数位不利于维护,在这里针对保留小数位封装成指令

指令核心

import Vue from 'vue'

const isNumber = val => typeof val === 'number' && val === val

// 使用 v-decimalsNum="2" 如果为0,则不保留小数位
Vue.directive('decimalsNum', {

  inserted: function (el, binding, vnode) {

    // 获取到input元素
    let targetObj = el.firstElementChild

    // 获取指定保留多少位小数
    let pos = binding.value && binding.value !== 0 ? binding.value : 2

    // 监听blur事件
    targetObj.addEventListener('blur', function (event) {

      if (!binding.value) {
        return
      }

      let v = parseFloat(targetObj.value)

      if (isNumber(v)) {

        let pow = Math.pow(10, pos)

        let result = (Math.round(v * pow) / pow).toString()

        targetObj.value = result

        vnode.data.model.callback(result)

      }

    })

  }
})
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值