Vue实现金钱输入框组件自动带千位逗号

新建PriceInput.vue

<template><div id="bord"><el-inputv-model="inputValue"v-bind="$attrs":maxlength="maxlength"@input="handleInput"@focus="handleFocus"@blur="handleBlur"@change="handleChange"><template slot="append"><slot name="append"></slot></template></el-input></div></template>

<script>
import { inputNumber } from '@/utils/inputNumber'
import { formatMoney } from '@/utils/formatMoney'
export default {// name:'priceInput',props: {value: {type: [String, Number],default: ''},// 金额位数格式(a-b);a:整数位数;b:小数位数format: {type: String,default: '9-2'}},data () {return {inputValue: '',inputing: false}},computed: {integerNum () {return Number(this.format.split('-')[0])},decimalNum () {return Number(this.format.split('-')[1])},maxlength () {return this.integerNum + (this.decimalNum > 0 ? this.decimalNum + 1 : this.decimalNum)}},watch: {value: {immediate: true,handler (n) {if (!n) {this.inputValue = nreturn}if (this.inputing) {this.inputValue = n} else {this.inputValue = formatMoney(inputNumber(n.toString()), this.format)}}}},methods: {handleInput (val) {this.inputing = truelet money = inputNumber(val)const format = this.formatconst intNum = Number(format.split('-')[0])const decimalNum = Number(format.split('-')[1])const moneyArr = money.split('.')moneyArr[0] = moneyArr[0].length > intNum ? moneyArr[0].substr(0, intNum) : moneyArr[0]if (moneyArr[1]) {moneyArr[1] = moneyArr[1].length > decimalNum ? moneyArr[1].substr(0, decimalNum) : moneyArr[1]}money = moneyArr.join('.')this.inputValue = moneylet value = ''if (money === '-' || money === '.') {value = ''} else if (money !== '') {value = Number(inputNumber(money))}this.$emit('input', value)},handleChange (val) {this.inputing = truethis.$emit('change', Number(val.replaceAll(',', '')))},handleBlur (e) {this.inputing = falsethis.inputValue = formatMoney(inputNumber(e.target.value), this.format)this.$emit('blur', e)},handleFocus (e) {this.inputing = truethis.inputValue = inputNumber(this.inputValue)this.$emit('focus', e)}}
}
</script>
<style>
#bord>.el-input>input{border: 0;outline: none;/* 清除边框 */text-align: right;font-size: 18px;background-color:transparent;/* 输入透明背景 */
}
</style>

formatMoney.js格式化金额

/*** 格式化金额* @param money { String / Number } 金额* @param format { String } a-b:限制输入的字符长度,a:整数长度,b:小数长度* @returns {string|null}*/
export const formatMoney = (money, format) => {if (typeof money === 'number') {money = money.toString()}if (money === '-' || !money) return moneyif (!format) format = '11-2'const intNum = Number(format.split('-')[0])const decimalNum = Number(format.split('-')[1])const moneyArr = money.split('.')moneyArr[0] = moneyArr[0].length > intNum ? moneyArr[0].substr(0, intNum) : moneyArr[0]if (moneyArr[1]) {moneyArr[1] = moneyArr[1].length > decimalNum ? moneyArr[1].substr(0, decimalNum) : moneyArr[1]}money = moneyArr.join('.')const isNegativeNum = money.startsWith('-')const pointPosition = money.indexOf('.')const decimal = pointPosition !== -1 ? money.substr(pointPosition) : ''const integer = Math.abs(parseInt(money).toString()).toString()const integerArrReverse = integer.split('').reverse().join('')const moneyStringify = `${isNegativeNum ? '-' : ''}${integerArrReverse.replace(/(\d{3})(?=\d)/g, '$1,').split('').reverse().join('')}${decimal}`return moneyStringify
}

inputNumber.js格式化为普通数字格式

// 此方法用来实现将一个字符串通过replace方法,格式化为普通数字格式(包括正负整数、正负浮点数都支持)
export const inputNumber = val => {if (val === '-' || !val) return valif (val === '.') return ''// 下列代码中正则表达式的非捕获组(?<=)在IE浏览器中不支持,所以弃用// const reg1 = /[^\d|^\-|\^.]/g // 匹配所有非数字,非-,非.的字符// const reg2 = /(?<=[\.|\-])[^\d]/g // 匹配所有.和-字符后的非数字字符// const reg3 = /(?<=\.\d*)\./g // 匹配小数后的.// const reg4 = /(?<=\d)\-/g // 匹配-后面的非数字// return val.replace(reg1, '').replace(reg2, '').replace(reg3, '').replace(reg4, '')const reg1 = /[^\d|\-|\.]/gconst reg2 = /(\d|\.)\-+/gconst str = val.replace(reg1, '').replace(reg2, '$1')const pointArr = str.split('.')let value = ''if (pointArr.length > 1) {pointArr.forEach((item, index) => {value = value + itemif (!index) {value = value + '.'}})} else {value = str}return value
}

使用案例

  <PriceInputv-model="yourModel":format="yourFormat"@input="yourInputHandler"@change="yourChangeHandler"@blur="yourBlurHandler"@focus="yourFocusHandler"/>
 export default {data() {return {yourModel: '', // 初始化你的模型值yourFormat: '11-2' // 初始化你的格式};},methods: {yourInputHandler(value) {console.log('Input:', value);},yourChangeHandler(newValue) {console.log('Changed:', newValue);},yourBlurHandler(event) {console.log('Blurred:', event);},yourFocusHandler(event) {console.log('Focused:', event);}}}

在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/40311.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ABAQUS山东济南青岛正版代理商亿达四方:构筑仿真技术新高地

在历史悠久而又充满活力的齐鲁大地上&#xff0c;济南与青岛作为山东省的两大核心城市&#xff0c;正引领着区域经济的蓬勃发展与科技创新。亿达四方&#xff0c;作为ABAQUS在山东济南与青岛的官方正版代理商&#xff0c;正以先进的仿真技术为基石&#xff0c;助力两地企业加速…

【GD32F303红枫派使用手册】第二十九节 USB-IAP升级实验

29.1 实验内容 通过本实验主要学习以下内容&#xff1a; USB IAP升级操作 29.2 实验原理 USB IAP升级本例程中使用的是Custom HID中的IAP设备类&#xff0c;其设备类协议的实现与HID的类似&#xff0c;主要包括GET_REPORT/GET_IDLE/GET_PROTOCOL/SET_REPORT/SET_IDLE/SET_P…

【Qt知识】qrc机制

在Qt中&#xff0c;qrc机制是一种资源管理系统&#xff0c;它允许你将应用程序所需的静态资源&#xff0c;如图像、样式表、字体和音频文件&#xff0c;嵌入到可执行文件中而不是作为外部文件存在。这样做的好处是资源管理更加安全&#xff0c;因为它们不会丢失或被意外修改&am…

git基本使用(一):git的基本概念

Git 是一种分布式版本控制系统&#xff0c;最初由 Linus Torvalds 于 2005 年为 Linux 内核开发。它主要用于跟踪文件的更改&#xff0c;特别是在软件开发过程中&#xff0c;可以帮助团队成员协同工作。它在实际项目开发中&#xff0c;应用非常广泛&#xff0c;我们这一节来掌握…

qt 滚动区域简单实验

1.概要 有些时候&#xff0c;想用一个有限的区域显示更多的内容&#xff0c;且内容不固定用滚动区域控件是一个不错的选择&#xff0c;我今天就用一个图片简单的实验一下。 2.代码&#xff08;关键代码&#xff09; #include "widget.h" #include "ui_widget…

flutter开发实战-Webview及dispose关闭背景音

flutter开发实战-Webview及dispose关闭背景音 当在使用webview的时候&#xff0c;dispose需要关闭网页的背景音或者音效。 一、webview的使用 在工程的pubspec.yaml中引入插件 webview_flutter: ^4.4.2webview_cookie_manager: ^2.0.6Webview的使用代码如下 初始化WebView…

uni-app上传失败超出文件限制解决方法-分包处理-预加载

分包背景 当你的上传出现一下错误&#xff1a; Error: 系统错误&#xff0c;错误码&#xff1a;80051,source size 2089KB exceed max limit 2MB [20240703 10:53:06][wxbf93dfb6cb3eb8af] [1.06.2405010][win32-x64] 说明你主包太大需要处理了&#xff0c;一下两种方法可以…

Day03-Jenkins与集成案例

Day03-Jenkins与集成案例 6. CD持续交付&#xff0c;持续部署实现方案7. 案例04: basketball案例,搭建开发测试专用的任务7.1 任务要求7.2 步骤7.3 详细步骤1&#xff09;安装插件2&#xff09;创建任务 7.4 gitlab配置钩子1) 解除钩子局域网访问限制2) gitlab配置钩子 7.5 与部…

网络基础:OSPF 协议

OSPF&#xff08;Open Shortest Path First&#xff09;是一种广泛使用的链路状态路由协议&#xff0c;用于IP网络中的内部网关协议&#xff08;IGP&#xff09;。OSPF通过在网络中的所有路由器之间交换路由信息&#xff0c;选择从源到目的地的最优路径。OSPF工作在OSI模型的第…

Nginx系列(二)---Mac上的快速使用

一、安装 前置软件&#xff1a;Homebrew 安装方法&#xff1a;终端输入/bin/bash -c "$(curl -fsSL <https://cdn.jsdelivr.net/gh/ineo6/homebrew-install/install.sh>)"更新&#xff1a; brew update 设置中科大镜像源&#xff1a;git -C "$(brew --r…

昇思25天学习打卡营第10天 | 自然语言处理:RNN实现情感分类

1. RNN实现情感分类 1.2 概述 情感分类是自然语言处理中的经典任务&#xff0c;是典型的分类问题。本节使用MindSpore实现一个基于RNN网络的情感分类模型&#xff0c;实现如下的效果&#xff1a; 输入: This film is terrible 正确标签: Negative(负面) 预测标签: Negative输…

初识Spark

一、简介 官网&#xff1a;Apache Spark™ - Unified Engine for large-scale data analytics Apache的顶级项目&#xff0c;用于大规模数据处理的统一分析引擎。 支持语言&#xff1a;Java、Scala、Python和R (源码为Scala) 高级工具&#xff1a; 1、SparkSQL用于SQL和结构…

Linux中cat命令的英文含义

我之前一直在想cat不是猫的意思吗&#xff0c;但是cat命令在Linux中并不是指"猫"这个动物&#xff0c;而是来源于它的功能&#xff1a;concatenate&#xff08;连接&#xff09;和typeset&#xff08;打印&#xff09;。这个命令的名称是这两个功能的首字母缩写。尽管…

DevExpress WPF中文教程:Grid - 如何显示摘要(设计时)?

DevExpress WPF拥有120个控件和库&#xff0c;将帮助您交付满足甚至超出企业需求的高性能业务应用程序。通过DevExpress WPF能创建有着强大互动功能的XAML基础应用程序&#xff0c;这些应用程序专注于当代客户的需求和构建未来新一代支持触摸的解决方案。 无论是Office办公软件…

Mac/Linux安装JMeter压测工具

Mac安装JMeter压测工具 介绍 Apache JMeter™应用程序是开源软件&#xff0c;是一个100%纯的Java应用程序&#xff0c;旨在加载测试功能行为和衡量性能。它最初是为测试Web应用程序而设计的&#xff0c;但后来扩展到其他测试功能。 我能用它做什么&#xff1f; Apache JMet…

vue高德地图使用

先根据官方方法给vue项目引入高德 高德文档地址 做好准备后使用 初始化地图 AMap.plugin(AMap.MoveAnimation, () >{//地图this.map new AMap.Map("mapContainer", {resizeEnable: true,center: [116.397447,39.909176],//地图中心坐标zoom:12,//缩放值});this.…

Appium+python自动化(三十九)-Appium自动化测试框架综合实践 - 代码实现(超详解)

1.简介 今天我们紧接着上一篇继续分享Appium自动化测试框架综合实践 - 代码实现。由于时间的关系&#xff0c;宏哥这里用代码给小伙伴演示两个模块&#xff1a;注册和登录。 2.业务模块封装 因为现在各种APP的层出不群&#xff0c;各式各样的。但是其大多数都有注册、登录。为…

走在健康前沿:低GI食品认证与现代饮食的新篇章

随着现代社会节奏的加快&#xff0c;人们对健康饮食的追求也日益增强。在众多饮食理念中&#xff0c;低血糖生成指数&#xff08;GI&#xff09;食品凭借其对控制血糖和预防慢性疾病的潜在益处&#xff0c;逐渐成为健康饮食领域的明星。 GI的科学解码 GI&#xff0c;即食物血糖…

CTFHUB-SSRF-URL Bypass

开启题目 给出提示&#xff0c;url参数的值中必须包含有 http://notfound.ctfhub.com &#xff0c;可以采用&#xff0c;也就是 HTTP 基本身份认证绕过 HTTP 基本身份认证允许 Web 浏览器或其他客户端程序在请求时提供用户名和口令形式的身份凭证的一种登录验证方式。 也就是…

AIGC文生图lora微调训练案例;SD-Train界面训练stable Diffusion lora模型

lora仓库&#xff08;1000多个lora微调模型分享&#xff09;&#xff1a; https://lorastudio.co/models 1、命令代码方式&#xff1a;文生图lora微调训练案例 主要用huggingface相关包&#xff1a;peft、accelerate、diffusers 参考&#xff1a; https://huggingface.co/blo…