vue.js

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript类库 > vue.js > el-input金额千分符自动转换

vue中el-input金额千分符自动转换的实现示例

作者:涛哥码咖

本文主要介绍了vue中el-input金额千分符自动转换,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

1. 说明

在平时项目中,对于金额处理显示一般需要按千分符显示,通常实现会申明一个formater函数来进行转换,但是涉及的地方比较多试,使用起来比较繁琐,封装一个单独的组件比较合理

2. 实现组件代码

<template>
  <div :style="{'background-color': disabled ? 'transparent' : '#fff'}">
    <span class="money-input" v-if="!isInput" @click="focusHanle" :disabled="disabled" :value="viewValue">{{ viewValue }}</span>
    <el-input ref="moneyInput" v-else v-bind="$attrs" :value="value" @input="handlerChange" @blur="handlerBlur" autofocus onkeypress="if(event.keyCode == 13) return false;"/>
  </div>
</template>
<script>
export default {
  name: 'ElMoneyInput',
  inheritAttrs: false,
  model: {
    prop: "value",
    event: "input"
  },
  props: {
    value: {
      type: String,
      default: ""
    },
    disabled:{
      type:Boolean,
      default:false
    },
    rules: {
      type: Object,
      default: () => {}
    }
  },
  watch: {
    value(val, old) {
      if (val !== old) {
        this.init()
      }
    }
  },
  mounted() {
    this.init()
  },
  data() {
    return {
      isEdit: true,
      isInput: false,
      viewValue: ''
    };
  },
  methods: {
    init() {
      if (!this.isInput) {
        this.viewValue = this.formatMoney(this.value || 0)
        this.$emit('input', this.blurformat(this.value || 0))
      }
    },
    focusHanle() {
      if (this.disabled) return
      this.isInput = !this.isInput
      this.$emit('input', this.blurformat(this.value || 0))
      this.$nextTick(() => {
        this.$refs.moneyInput.focus()
      })
    },
    formatMoney(cellValue, num = 2) {
      if (isNaN(cellValue)) {
        return ""
      }
      if (cellValue === 0) {
        return '0.00';
      }
      return this.$Utils.formatMoney(cellValue, num);
    },
    format(v) {
      return (`${v}`.match(/([\d\.]+)/) || "")[0];
    },
    blurformat(v) {
      return v ? Number.parseFloat(v).toFixed(2) : "";
    },
    handlerChange(v) {
      this.$emit('input', v)
    },
    handlerBlur() {
      this.isInput = false;
      this.$emit('input', this.blurformat(this.value))
      this.viewValue = this.formatMoney(this.value)
    },
    // handleFocus() {
    //   this.isInput = true;
    //   this.$emit('input', this.blurformat(this.value))
    // }
  }
};
</script>
<style lang="less">
.span-input{
  display: inline-block;
  width: 100%;
  height:28px;
}
.money-input {
  position: relative;
  font-size: 14px;
  display: inline-block;
  height: 32px;
  line-height: 32px;
  background: transparent !important;
    cursor: text !important;
    background-color: #FFF;
    background-image: none;
    border-radius: 4px;
    border: 1px solid #DCDFE6;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    color: #606266;
    display: inline-block;
    font-size: inherit;
    outline: 0;
    padding: 0 15px;
    -webkit-transition: border-color .2s cubic-bezier(.645,.045,.355,1);
    transition: border-color .2s cubic-bezier(.645,.045,.355,1);
    width: 100%;
  .el-input__inner {
    background: transparent !important;
    cursor: text !important;
    background-color: #FFF;
    background-image: none;
    border-radius: 4px;
    border: 1px solid #DCDFE6;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    color: #606266;
    display: inline-block;
    font-size: inherit;
    height: 40px;
    line-height: 40px;
    outline: 0;
    padding: 0 15px;
    -webkit-transition: border-color .2s cubic-bezier(.645,.045,.355,1);
    transition: border-color .2s cubic-bezier(.645,.045,.355,1);
    width: 100%;
  }
}
</style>

3.实现效果

在这里插入图片描述

到此这篇关于vue中el-input金额千分符自动转换的文章就介绍到这了,更多相关el-input金额千分符自动转换内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

您可能感兴趣的文章:
阅读全文