为了账号安全,请及时绑定邮箱和手机立即绑定

基于 elementUI 二次封装的 Format 输入框 组件

标签:
Vue.js

最近封装了一个可以自带format的输入框组件,效果如下:

https://img1.sycdn.imooc.com//5bd95df40001c98103640053.jpg

我所封装的组件代码如下:

<template>
  <div>
    <el-input v-model="startValue"
         @blur="startInput" 
         :maxlength="maxlength"></el-input>
    <i class="el-icon-minus padding-top-5"></i>
    <el-input v-model="endValue"
          @blur="endInput" 
          :maxlength="maxlength"></el-input>
  </div>
</template>

<script>
export default {
  name: "input-format-range",
  props:['startName','endName','maxlength'],
  data:()=>({
    startValue:'',
    endValue:''
  }),
  methods:{
    checkInput({value}){
      value=value?parseFloat(value.toString().replace(/[^0-9._-]/g, ''))||0:'';
      let formattedValue = '';
      if (value !== 0 && value !== '')
          formattedValue = Number(value)
                   .toFixed(2)
                   .replace(/\d{1,3}(?=(\d{3})+(\.\d*)?$)/g,'$&,');
       else
        formattedValue = value;
        
      return formattedValue;
    },
    startInput({target}){
      this.startValue = this.checkInput(target);
      this.$emit('checkInput',{startValue:this.startValue,
                               startName:this.startName,
                               endValue:this.endValue,
                               endName:this.endName});
    },
    endInput({target}){
      this.endValue = this.checkInput(target);
      this.$emit('checkInput',{startValue:this.startValue,
                               startName:this.startName,
                               endValue:this.endValue,
                               endName:this.endName});
    }
  }
}
</script>

如果传给后台要纯数字类型,你还需要去掉里面的逗号,你可以在main.js里面定义如下函数:

Vue.prototype.splitValue = function (value) {
  value = value? parseFloat(value.replace(/,/g ,'')) || 0 : '';
  return value
};

在父组件中就可以愉快的使用了~:

<template>
      <inputFormatRange @checkInput="checkPrice"
                :maxlength="9"
                :startName="'costPriceFrom'"
                :endName="'costPriceTo'"></inputFormatRange>
</template>

<script>
import inputFormatRange from '@/components/inputFormatRange.vue'
export default {
  name: "price-manage",
  components:{inputFormatRange},
  data:()=>({
    getTable:{
      costPriceFrom: '',
      costPriceTo: ''
     }
  }),
  methods:{
    checkPrice(obj){
      this.getTable[obj.startName] = this.splitValue(obj.startValue);
      this.getTable[obj.endName] = this.splitValue(obj.endValue);
    }
  }
}
</script>


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
Web前端工程师
手记
粉丝
61
获赞与收藏
656

关注作者,订阅最新文章

阅读免费教程

  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消