因工作要求,需要验证会计使用的公式,写了一个js类,在此一做记录
/**************************************************
* 此类用来验证公式合法性<br>
* 公式输入说明:<br>
* 1、可以输入数值常量。50、20.3<br>
* 2、可以报表单元格列表中选取需要的单元格。R.001.A04<br>
* 3、可以使用+,-,*,/运算符和括号(,)。<br>
* <br>
* 正确公式示例:<br>
* //正确公式 (R.001.A04+R.001.A04+R.001.A03)/50-R.001.A06/8.05*166 <br>
* //错误公式 (R.0011.A04+R.001.A04+R.001.A03)/50-R.001.A06/8.05*166<br>
* <br>
* <br>
* 使用示例:<br>
* 创建公式<br>
* var tStr = "(R.001.A04+R.001.A04+R.001.A03)/50-R.001.A06/8.05*166";<br>
* 创建验证公式对象<br>
* var fromsV = new FromsUtil();<br>
* 调用验证方法<br>
* fromsV.validateFroms(tStr);<br>
* 取得验证结果<br>
* alert(fromsV.validateFlag);<br>
* <br>
*************************************************/
FromsUtil = function() {
//加、减、乘、除
this.patt = /[+\-\/\*]/;
//验证公式元素:R.001.A04--(R.001.A04--R.001.A04)--22--22.22
//var patt2 = /^\({0,}R\.\d{3}\.[A-Z]\d{2}\){0,}$|^\d{1,}$|^\d{1,}\.\d{1,}$/;
//常量前后也可有括号
this.patt2 = /^\({0,}R\.\d{3}\.[A-Z]\d{2}\){0,}$|^\({0,}\d{1,}\){0,}$|^\({0,}\d{1,}\.\d{1,}\){0,}$/;
//验证结果
this.validateFlag = true;
//括号个数
this.patt3 = /\(/g;
this.patt4 = /\)/g;
var leftBracket=0;
var rigthBracket=0;
var count = 0; //递归次数--来确定是否有计算符号
//验证公式的主要方法
this.validateFroms = function (str) {
//取得匹配的字符串
var tem1 = str.match(this.patt);
//alert(tem1);
//假如为空为最后一个元素
if(tem1 == null) {
//假如无计算符返回false
if(count==0) {
if(str.match(this.patt) == null) {
this.validateFlag = false;
return;
}
}
//验证最后一个元素
if(!(this.patt2.test(str))) {
this.validateFlag = this.patt2.test(str);
return;
}
//取得括号的个数
while (this.patt3.exec(str) != null) {
leftBracket++;
}
while (this.patt4.exec(str) != null) {
rigthBracket++;
}
//验证括号个烽
if(leftBracket!=rigthBracket) {
this.validateFlag=false;
}
return;
};
//取得位置
var index = str.indexOf(tem1);
//取得要验证的字符串
var str1=str.substring(0,index);
//alert(str1);
//alert(patt2.test(str1));
//验证结果
if(!(this.patt2.test(str1))) {
this.validateFlag = this.patt2.test(str1);
return;
}
//取得括号的个数
while (this.patt3.exec(str1) != null) {
leftBracket++;
}
while (this.patt4.exec(str1) != null) {
rigthBracket++;
}
count ++;
//使用递归
var str2=str.substring(index+1,str.length);
this.validateFroms(str2);
}
}
分享到:
相关推荐
JS正则验证,不错的小东西。
一个正则表达式验证格式的方法 你一个可以调用的demo valid(str,tostr) str:字符串 tostr:格式 yy-mm-dd 支持.,/,-三种格式。
需要.net环境 正则验证软件正则验证软件正则验证软件正则验证软件正则验证软件正则验证软件正则验证软件正则验证软件。
常用正则验证,各种常用验证包含,汉字、手机号、电话号码、email、金额、特殊字符等常见完整js类库。
正则表达式 JS 身份证验证 正则表达式 JS 身份证验证 正则表达式 JS 身份证验证
js正则验证规则大全,只用下载一次,以后就不用在找了
关于身份证号,出生日期等的js正则表达式验证 有几种方式
JS input输入框 英文 中文 邮箱 手机号 银行卡 身份证等等各种正则验证 确保上传的内容合法合规,涉及侵权内容将会被移除
NULL 博文链接:https://onestopweb.iteye.com/blog/2376832
jq非空验证,为空的时候input后面加红色字体的用户名不能为空。 js正则表达式验证邮箱和手机号码,验证邮箱必须含有@符,手机号码必须1开头并且固定11个字符
常用js正则表达式 开发必备 只能输入数字:“^[0-9]*$” 只能输入n位的数字:“^\d{n}$” 只能输入至少n位数字:“^\d{n,}$” 只能输入m-n位的数字:“^\d{m,n}$” 只能输入零和非零开头的数字:“^(0|[1-9][0-9]*)...
JS正则验证大全 (.Net客户端验证)
JS配合正则对表单验证,里面还有一个html5新的验证表单API。
正则验证大全正则验证大全正则验证大全正则验证大全
需要.net环境 正则验证软件正则验证软件正则验证软件正则验证软件正则验证软件正则验证软件
JavaScript正则验证手机格式Demo,js使用正则表达式,用来验证手机的正确格式,可检测出是否为手机号码的Demo
autoit 正则验证工具 用穷举的方法生成图片 验证正则表达式完备性
js正则表达式表单验证小案例
JavaScript正则表达式验证身份证号码是否合法(两种方法)分析.docx
**最主要特点可以把正则后的结果加亮显示** 简单易用的HTML形式: 1....有很多正则库 3.支持多种浏览器IE FF 都测试成功 <br>无论你是新手还是高手一旦拥有它你会更随意的去运用正则表达式的!