Js 小數(shù)驗(yàn)證函數(shù)代碼(基于正則)
更新時(shí)間:2010年05月31日 23:51:15 作者:
經(jīng)常需要使用JS來(lái)驗(yàn)證一些數(shù)字(OnKeyPress 事件和onblur事件來(lái)驗(yàn)證),寫了兩個(gè)事件來(lái)驗(yàn)證,驗(yàn)證了一般情況。
(1)OnKeyPress 事件驗(yàn)證 用來(lái)驗(yàn)證輸入操作
function OnKeyPressValidate(obj, event, len) {
var e = window.event || event;
var key = e.keyCode ? e.keyCode : e.which;
var selectedText = "";
if (window.getSelection) {
var st = obj.selectionStart;
var ed = obj.selectionEnd;
selectedText = obj.value.substring(st, ed);
} else if (document.selection) {
selectedText = document.selection.createRange().text;
}
if (selectedText != null && selectedText != "") {
return true;
}
var dot = obj.value.indexOf(".");
len = (typeof (len) == "undefined") ? 2 : len;
if (window.event) {
}
else {
if (key == 8 || key == 9 || key == 46 || (key >= 37 && key <= 40))//for Firefox
return true;
}
if (key <= 57 && key >= 48) {
if (dot == -1)
return true;
else if (obj.value.length <= dot + len)
return true;
} else if ((key == 46) && dot == -1) {
return true;
}
return false;
}
(2)onblur 事件驗(yàn)證 用來(lái)驗(yàn)證最終的數(shù)據(jù)
function OnBlurValidate(obj, messageId) {
var tempValue = trim(obj.value);
var message = document.getElementById(messageId);
if (tempValue == "") {
MessageShow("", message, false);
return true;
}
else {
var regu = /^(\d+)(\.?)(\d{0,2})$/;
var re = new RegExp(regu);
if (!re.test(tempValue)) {
MessageShow("Number must be in this format (###.##) or (###)", message, true);
return false;
}
else {
MessageShow("", message, false);
return true;
}
}
}
復(fù)制代碼 代碼如下:
function OnKeyPressValidate(obj, event, len) {
var e = window.event || event;
var key = e.keyCode ? e.keyCode : e.which;
var selectedText = "";
if (window.getSelection) {
var st = obj.selectionStart;
var ed = obj.selectionEnd;
selectedText = obj.value.substring(st, ed);
} else if (document.selection) {
selectedText = document.selection.createRange().text;
}
if (selectedText != null && selectedText != "") {
return true;
}
var dot = obj.value.indexOf(".");
len = (typeof (len) == "undefined") ? 2 : len;
if (window.event) {
}
else {
if (key == 8 || key == 9 || key == 46 || (key >= 37 && key <= 40))//for Firefox
return true;
}
if (key <= 57 && key >= 48) {
if (dot == -1)
return true;
else if (obj.value.length <= dot + len)
return true;
} else if ((key == 46) && dot == -1) {
return true;
}
return false;
}
(2)onblur 事件驗(yàn)證 用來(lái)驗(yàn)證最終的數(shù)據(jù)
復(fù)制代碼 代碼如下:
function OnBlurValidate(obj, messageId) {
var tempValue = trim(obj.value);
var message = document.getElementById(messageId);
if (tempValue == "") {
MessageShow("", message, false);
return true;
}
else {
var regu = /^(\d+)(\.?)(\d{0,2})$/;
var re = new RegExp(regu);
if (!re.test(tempValue)) {
MessageShow("Number must be in this format (###.##) or (###)", message, true);
return false;
}
else {
MessageShow("", message, false);
return true;
}
}
}
您可能感興趣的文章:
- javascript 手機(jī)號(hào)碼正則表達(dá)式驗(yàn)證函數(shù)
- js正則函數(shù)match、exec、test、search、replace、split使用介紹集合
- js 正則表達(dá)式之test函數(shù)講解
- JS驗(yàn)證URL函數(shù) 正則
- js 替換功能函數(shù),用正則表達(dá)式解決,js的全部替換
- js正則表達(dá)式之match函數(shù)講解
- JavaScript基于正則表達(dá)式的數(shù)字判斷函數(shù)
- 用正則表達(dá)式判斷字符串是漢字還是拼音的js函數(shù)代碼
- js正則表達(dá)式之replace函數(shù)用法
- javascript中基于replace函數(shù)的正則表達(dá)式語(yǔ)法
- JavaScript 正則表達(dá)式驗(yàn)證函數(shù)代碼
- trim原型函數(shù)看js正則表達(dá)式的性能
- JavaScript常用正則函數(shù)用法示例
相關(guān)文章
解讀郵箱正則表達(dá)式:^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$
這篇文章主要介紹了解讀郵箱正則表達(dá)式:^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$,需要的朋友可以參考下2020-02-02notepad++批量去掉或替換文本中的換行符、提取指定行或內(nèi)容(推薦)
這篇文章主要介紹了notepad++批量去掉或替換文本中的換行符、提取指定行或內(nèi)容,需要的朋友可以參考下2023-07-07正則表達(dá)式小腳本(對(duì)輸入內(nèi)容進(jìn)行處理)
該小腳本實(shí)現(xiàn)的是對(duì)輸入框內(nèi)容中取出<img>標(biāo)簽中的src中的內(nèi)容,然后在原來(lái)位置進(jìn)行替換內(nèi)容,然后在去除輸入內(nèi)容中的html標(biāo)簽,空格等操作2016-12-12用正則實(shí)現(xiàn)提取代碼內(nèi)容的代碼
用正則實(shí)現(xiàn)提取代碼內(nèi)容的代碼...2007-03-03JavaScript中常用的正則表達(dá)式日常整理(全)
本篇文章是小編日常整理有關(guān)js常用的正則表達(dá)式,比較全面,對(duì)大家學(xué)習(xí)javascript正則表達(dá)式非常有用,需要的朋友一起學(xué)習(xí)吧2015-09-09