Jquery实时校验,指定长度的「负小数」,小数位未满末尾补0
yuyutoo 2024-11-14 19:54 3 浏览 0 评论
在可以输入【负小数】的输入框获取到焦点时,移除千位分隔符,
在输入数据时,实时校验输入内容是否正确,
失去焦点后,添加千位分隔符格式化数字。同时小数位未满时末尾补0。
HTML代码
<input type="text" class="force-sign-decimalToFixed-2-3" .../>
JS调用方法
$(document.body).find("input[type=text]").each(function() {
// 验证输入内容
callCustomiseInputCheck(this);
});
实时校验【负小数】,小数位未满时补0。
function callCustomiseInputCheck(inputObject) {
jQuery.each(inputObject.classList, function(itemIndex, classItem) {
//例:<input type="text" class="force-sign-decimalToFixed-2-3" .../> 整数部桁数:2、小数部桁数:3
if (/^force\-sign\-decimalToFixed\-\d{1,}\-\d{1,}$/.test(classItem)) {
// 方法【runInputFilter】,参照文章【Jquery实时验证,只能输入指定长度的数字】
runInputFilter(inputObject, ',', function(value) {
if (/^\-?\d*\.?\d*$/.test(value)) {//数字的场合
var jsInteger = value.split('.')[0];//整数部
var jsScale = value.split('.')[1];//小数部
//整数部分越界的场合
if (jsInteger && parseInt(jsInteger) > 0
&& jsInteger.replace('-', '').length > parseInt(classItem.split('-')[3])) {
return false;
}
//小数部分越界的场合
if (jsScale && parseInt(jsScale) > 0
&& jsScale.length > parseInt(classItem.split('-')[4])) {
return false;
}
return true;
} else {
//不是数字的场合
return false;
}
});
//格式化
postLostFocus(inputObject, function(inputObject) {
if (inputObject.value == "") {
return false;
}
if (!inputObject.value.contains('.')) {
inputObject.value = inputObject.value + '.';
}
var regExp = RegExp(/^(\-?)(0{1,})?(\d*\.?\d*)$/);
var outPutArray = inputObject.value.match(regExp);
inputObject.value = outPutArray[1] + outPutArray[3];//去掉左侧重复的0(例:「-0012?-12」、「-0012.23?-12.23」)
var classItemLength = classItem.split('-').length
if (classItemLength == 5) {//指定小数位数的场合
var jsScale = parseInt(classItem.split('-')[4]);//小数部
inputObject.value = inputObject.value.split('.')[0] + '.' + inputObject.value.split('.')[1]).padEnd(jsScale, '0')//小数末尾补0
}
inputObject.value = CommonUtilJs.addComma(inputObject.value)
//去掉负数0的负号
if (/^[\-0*\.?0*]*$/.test(inputObject.value)) {
inputObject.value = inputObject.value.replace(/^(\-)([0*\.?0*]*)$/, function($0, $1, $2) {
return $2;
});
}
});
//终止循环
return false;
}
});
}
共通处理方法
/**
* 绑定失去焦点时的处理
* @param textbox HTML输入框
* @param lostFocusFunction 失去焦点时的处理
* 例:postLostFocus(ocument.getElementById("XXX"),functionXXXXX);
*/
function postLostFocus(textbox, lostFocusFunction) {
["focusout"].forEach(function(event) {
var eventCommonPostLostFocus = function(event) {
lostFocusFunction(this);
}
// 参照文章【前端Jquery调用on或bind方法,避免重复绑定】
addEventExtras(textbox, event, eventCommonPostLostFocus);
});
}
function CommonUtilJs() { }
//数值格式化
CommonUtilJs.addComma = function(value) {
var patern = /^([\+\-]?\d+)(\d{3})([\,\d+]*)(\.\d+)?$/;
var rep = "";
var val = "";
if (value != undefined && value != null) {
val = String(value);
while (rep != val) {
rep = val;
val = rep.replace(patern, "$1,$2$3$4");
}
}
return val;
};
相关推荐
- JavaWeb开发入门需要学哪些?看完你就懂了
-
目前,国内外信息化建设已经进入基于Web应用为核心的阶段,Java作为应用于网络的最好语言,前景无限看好。然而,就算用Java建造一个不是很烦琐的web应用,也不是件轻松的事情。那么,本文章就来详细说...
- Spring Boot 中如何实现通过Cookie来实现用户鉴权?
-
Cookie是存储在用户浏览器中的一小段数据,主要的作用是用来帮助Web服务器和客户端之间的通信。这段数据由服务端生成,然后通过HTTP的头部信息反馈给客户端,然后再后续的操作中客户端会自动将这些Co...
- Session和cookie笔记 session与cookie的关系
-
会话技术1.会话:一次会话中包含多次请求和响应。*一次会话:浏览器第一次给服务器资源发送请求,会话建立,直到有一方断开为止2.功能:在一次会话的范围内的多次请求间,共享数据3.方式:1.客户...
- 精读大型网站架构的技术细节:后端架构规整化Cookie和Session
-
Cookie和Session接口请求(HTTP请求)是无状态的,每次请求都是完全独立的。也就是说,在处理请求时,Web应用服务器无法得知这个请求是哪个用户发送的,无法跟踪上一次请求的状态。但是,有些时...
- 一文彻底搞懂Cookie、Session、Token到底是什么
-
一、Cookie洛:大爷,楼上322住的是马冬梅家吧?大爷:马都什么?夏洛:马冬梅。大爷:什么都没啊?夏洛:马冬梅啊。大爷:马什么没?夏洛:行,大爷你先凉快着吧。在了解这三个概念之前我们...
- Python常用的第三方包-Requests 5个常用python第三方库
-
在现代互联网时代,进行网络请求是开发人员经常需要处理的任务之一。Python的Requests包是一个强大而易于使用的工具,可以简化网络请求的过程,并提供了丰富的功能。本文将深入介绍如何使用Pytho...
- 干货 | REST-assured 获取日志到文件并结合 Allure 报告进行展示
-
使用Rest-assured集合Allure运行完用例之后,在生成的报告中只有断言信息,没有请求的日志信息。而当我们的用例失败时,特别是接口失败时,请求日志是分析原因的第一手资源。那如何将R...
- 前后端数据交互(四)——fetch 请求详解
-
fetch是XMLHttpRequest的升级版,使用js脚本发出网络请求,但是与XMLHttpRequest不同的是,fetch方式使用Promise,相比XMLHttpReques...
- 【0基础学爬虫】爬虫基础之网络请求库的使用
-
大数据时代,各行各业对数据采集的需求日益增多,网络爬虫的运用也更为广泛,越来越多的人开始学习网络爬虫这项技术,K哥爬虫此前已经推出不少爬虫进阶、逆向相关文章,为实现从易到难全方位覆盖,特设【0基础学爬...
- ASP.NET MVC开发日常一:SessionID更新
-
在MVCWeb开发中临时存储数据一般会用到Session,Cookie,ViewBag,ViewData,TempData。每个的使用场景是不同,具体区别有空再补上。Session数据最敏感,最需要...
- 如何抓取有密码网页表格数据?简单易行!
-
众所周知,表格是一种常见的数据展示方式,而在网络世界中,许多网站也会采用表格的形式展示数据。但如果需要抓取这些表格中的数据,尤其是有帐号密码保护的网页,该如何实现呢?本文将为大家提供一种简单易行的方法...
- 不背锅运维:Grafana的自动登入(Go和Python分别实现)
-
1.实现目标想要达到的目标是:当在浏览器向http://192.168.11.254:3090/auto_login这个地址发起GET请求后能够自动登入Grafana...
- Python每日一库之requests python爬虫之requests库的下载
-
Pythonurllib...
- Javaweb知识 day16 Cookie&Session
-
今日内容1.会话技术1.Cookie2.Session2.JSP:入门学习一、会话技术1.1概念:会话:浏览器第一次给服务器资源发送请求,会话建立,直到有一方断开为止,一次会话中包含多次请...
- 全网最全的python网络爬虫常用技术
-
前言urllib模块urllib库是python中自带的模块,也是一个最基本的网络请求库,该模块提供了一个urlopen()方法,通过该方法指定URL发送网络请求来获取数据。正文urllib是一个收...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- JavaWeb开发入门需要学哪些?看完你就懂了
- Spring Boot 中如何实现通过Cookie来实现用户鉴权?
- Session和cookie笔记 session与cookie的关系
- 精读大型网站架构的技术细节:后端架构规整化Cookie和Session
- 一文彻底搞懂Cookie、Session、Token到底是什么
- Python常用的第三方包-Requests 5个常用python第三方库
- 干货 | REST-assured 获取日志到文件并结合 Allure 报告进行展示
- 前后端数据交互(四)——fetch 请求详解
- 【0基础学爬虫】爬虫基础之网络请求库的使用
- ASP.NET MVC开发日常一:SessionID更新
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)