javascript函数

简介:
javascript函数库
trim() lTrim() rTrim()
校验字符串是否为空: checkIsNotEmpty(str)
校验字符串是否为整型: checkIsInteger(str)
校验整型最小值: checkIntegerMinValue(str,val)
校验整型最大值: checkIntegerMaxValue(str,val) 
校验整型是否为非负数: isNotNegativeInteger(str)
校验字符串是否为浮点型: checkIsDouble(str) 
校验浮点型最小值: checkDoubleMinValue(str,val)
校验浮点型最大值: checkDoubleMaxValue(str,val)
校验浮点型是否为非负数: isNotNegativeDouble(str)
校验字符串是否为日期型: checkIsValidDate(str)
校验两个日期的先后: checkDateEarlier(strStart,strEnd)
校验字符串是否为email型: checkEmail(str)

校验字符串是否为中文: checkIsChinese(str)
计算字符串的长度,一个汉字两个字符: realLength()
校验字符串是否符合自定义正则表达式: checkMask(str,pat)
得到文件的后缀名: getFilePostfix(oFile) 
-------------- 函数检索 --------------
*/

/**
* added by LxcJie 2004.6.25
* 去除多余空格函数
* trim:去除两边空格 lTrim:去除左空格 rTrim: 去除右空格
* 用法:
* var str = " hello ";
* str = str.trim();
*/
String.prototype.trim = function()
{
 return this.replace(/(^[\\s]*)|([\\s]*$)/g, "");
}
String.prototype.lTrim = function()
{
 return this.replace(/(^[\\s]*)/g, "");
}
String.prototype.rTrim = function()
{
 return this.replace(/([\\s]*$)/g, "");
}

/**
*校验字符串是否为空
*返回值:
*如果不为空,定义校验通过,返回true
*如果为空,校验不通过,返回false 参考提示信息:输入域不能为空!
*/
function checkIsNotEmpty(str)
{
 if(str.trim() == "")
 return false;
 else
 return true;
}

/**
*校验字符串是否为整型
*返回值:
*如果为空,定义校验通过, 返回true
*如果字串全部为数字,校验通过,返回true
*如果校验不通过, 返回false 参考提示信息:输入域必须为数字!
*/
function checkIsInteger(str)
{
 //如果为空,则通过校验
 if(str == "")
 return true;
 if(/^(\\-?)(\\d+)$/.test(str))
 return true;
 else
 return false;
}

/**
*校验整型最小值
*str:要校验的串。 val:比较的值
*
*返回值:
*如果为空,定义校验通过, 返回true
*如果满足条件,大于等于给定值,校验通过,返回true
*如果小于给定值, 返回false 参考提示信息:输入域不能小于给定值!
*/
function checkIntegerMinValue(str,val)
{
 //如果为空,则通过校验
 if(str == "")
 return true;
 if(typeof(val) != "string")
 val = val + "";
 if(checkIsInteger(str) == true)
 {
 if(parseInt(str,10)>=parseInt(val,10))
 return true;
 else
 return false;
 }
 else
 return false;
}

/**
*校验整型最大值
*str:要校验的串。 val:比较的值
*
*返回值:
*如果为空,定义校验通过, 返回true
*如果满足条件,小于等于给定值,校验通过,返回true
*如果大于给定值, 返回false 参考提示信息:输入值不能大于给定值!
*/
function checkIntegerMaxValue(str,val)
{
 //如果为空,则通过校验
 if(str == "")
 return true;
 if(typeof(val) != "string")
 val = val + "";
 if(checkIsInteger(str) == true)
 {
 if(parseInt(str,10)<=parseInt(val,10))
 return true;
 else
 return false;
 }
 else
 return false;
}

/**
*校验整型是否为非负数
*str:要校验的串。
*
*返回值:
*如果为空,定义校验通过,返回true
*如果非负数, 返回true
*如果是负数, 返回false 参考提示信息:输入值不能是负数!
*/
function isNotNegativeInteger(str)
{
 //如果为空,则通过校验
 if(str == "")
 return true;
 if(checkIsInteger(str) == true)
 {
 if(parseInt(str,10) < 0)
 return false;
 else
 return true;
 }
 else
 return false;
}

/**
*校验字符串是否为浮点型
*返回值:
*如果为空,定义校验通过, 返回true
*如果字串为浮点型,校验通过, 返回true
*如果校验不通过, 返回false 参考提示信息:输入域不是合法的浮点数!
*/
function checkIsDouble(str)
{
 //如果为空,则通过校验
 if(str == "")
 return true;
 //如果是整数,则校验整数的有效性
 if(str.indexOf(".") == -1)
 {
 if(checkIsInteger(str) == true)
 return true;
 else
 return false;
 }
 else
 {
 if(/^(\\-?)(\\d+)(.{1})(\\d+)$/g.test(str))
 return true;
 else
 return false;
 }
}

/**
*校验浮点型最小值
*str:要校验的串。 val:比较的值
*
*返回值:
*如果为空,定义校验通过, 返回true
*如果满足条件,大于等于给定值,校验通过,返回true
*如果小于给定值, 返回false 参考提示信息:输入域不能小于给定值!
*/
function checkDoubleMinValue(str,val)
{
 //如果为空,则通过校验
 if(str == "")
 return true;
 if(typeof(val) != "string")
 val = val + "";
 if(checkIsDouble(str) == true)
 {
 if(parseFloat(str)>=parseFloat(val))
 return true;
 else
 return false;
 }
 else
 return false;
}

/**
*校验浮点型最大值
*str:要校验的串。 val:比较的值
*
*返回值:
*如果为空,定义校验通过, 返回true
*如果满足条件,小于等于给定值,校验通过,返回true
*如果大于给定值, 返回false 参考提示信息:输入值不能大于给定值!
*/
function checkDoubleMaxValue(str,val)
{
 //如果为空,则通过校验
 if(str == "")
 return true;
 if(typeof(val) != "string")
 val = val + "";
 if(checkIsDouble(str) == true)
 {
 if(parseFloat(str)<=parseFloat(val))
 return true;
 else
 return false;
 }
 else
 return false;
}

/**
*校验浮点型是否为非负数
*str:要校验的串。
*
*返回值:
*如果为空,定义校验通过,返回true
*如果非负数, 返回true
*如果是负数, 返回false 参考提示信息:输入值不能是负数!
*/
function isNotNegativeDouble(str)
{
 //如果为空,则通过校验
 if(str == "")
 return true;
 if(checkIsDouble(str) == true)
 {
 if(parseFloat(str) < 0)
 return false;
 else
 return true;
 }
 else
 return false;
}

/**
*校验字符串是否为日期型
*返回值:
*如果为空,定义校验通过, 返回true
*如果字串为日期型,校验通过, 返回true
*如果日期不合法, 返回false 参考提示信息:输入域的时间不合法!(yyyy-MM-dd)
*/
function checkIsValidDate(str)
{
 //如果为空,则通过校验
 if(str == "")
 return true;
 var pattern = /^((\\d{4})|(\\d{2}))-(\\d{1,2})-(\\d{1,2})$/g;
 if(!pattern.test(str))
 return false;
 var arrDate = str.split("-");
 if(parseInt(arrDate[0],10) < 100)
 arrDate[0] = 2000 + parseInt(arrDate[0],10) + "";
 var date = new Date(arrDate[0],(parseInt(arrDate[1],10) -1)+"",arrDate[2]);
 if(date.getYear() == arrDate[0]
 && date.getMonth() == (parseInt(arrDate[1],10) -1)+""
 && date.getDate() == arrDate[2])
 return true;
 else
 return false;
}

/**
*校验两个日期的先后
*返回值:
*如果其中有一个日期为空,校验通过, 返回true
*如果起始日期早于等于终止日期,校验通过, 返回true
*如果起始日期晚于终止日期, 返回false 参考提示信息: 起始日期不能晚于结束日期。
*/
function checkDateEarlier(strStart,strEnd)
{
 if(checkIsValidDate(strStart) == false || checkIsValidDate(strEnd) == false)
 return false;
 //如果有一个输入为空,则通过检验
 if (( strStart == "" ) || ( strEnd == "" ))
 return true;
 var arr1 = strStart.split("-");
 var arr2 = strEnd.split("-");
 var date1 = new Date(arr1[0],parseInt(arr1[1].replace(/^0/,""),10) - 1,arr1[2]);
 var date2 = new Date(arr2[0],parseInt(arr2[1].replace(/^0/,""),10) - 1,arr2[2]);
 if(arr1[1].length == 1)
 arr1[1] = "0" + arr1[1];
 if(arr1[2].length == 1)
 arr1[2] = "0" + arr1[2];
 if(arr2[1].length == 1)
 arr2[1] = "0" + arr2[1];
 if(arr2[2].length == 1)
 arr2[2]="0" + arr2[2];
 var d1 = arr1[0] + arr1[1] + arr1[2];
 var d2 = arr2[0] + arr2[1] + arr2[2];
 if(parseInt(d1,10) > parseInt(d2,10))
 return false;
 else
 return true;
}

/**
*校验字符串是否为email型
*返回值:
*如果为空,定义校验通过, 返回true
*如果字串为email型,校验通过, 返回true
*如果email不合法, 返回false 参考提示信息:Email的格式不正確!
*/
function checkEmail(str)
{
 //如果为空,则通过校验
 if(str == "")
 return true;
 if (str.charAt(0) == "." || str.charAt(0) == "@" || str.indexOf(\'@\', 0) == -1
 || str.indexOf(\'.\', 0) == -1 || str.lastIndexOf("@") == str.length-1 || str.lastIndexOf(".") == str.length-1)
 return false;
 else
 return true;
}

/**
*校验字符串是否为中文
*返回值:
*如果为空,定义校验通过, 返回true
*如果字串为中文,校验通过, 返回true
*如果字串为非中文, 返回false 参考提示信息:必须为中文!
*/
function checkIsChinese(str)
{
 //如果值为空,通过校验
 if (str == "")
 return true;
 var pattern = /^([\\u4E00-\\u9FA5]|[\\uFE30-\\uFFA0])*$/gi;
 if (pattern.test(str))
 return true;
 else
 return false;
}

/**
* 计算字符串的长度,一个汉字两个字符
*/
String.prototype.realLength = function()
{
 return this.replace(/[^\\x00-\\xff]/g,"**").length;
}

/**
*校验字符串是否符合自定义正则表达式
*str 要校验的字串 pat 自定义的正则表达式
*返回值:
*如果为空,定义校验通过, 返回true
*如果字串符合,校验通过, 返回true
*如果字串不符合, 返回false 参考提示信息:必须满足***模式
*/
function checkMask(str,pat)
{
 //如果值为空,通过校验
 if (str == "")
 return true;
 var pattern = new RegExp(pat,"gi")
 if (pattern.test(str))
 return true;
 else
 return false;
}

/**
* added by LxcJie 2004.6.25
* 得到文件的后缀名
* oFile为file控件对象
*/
function getFilePostfix(oFile)
{
 if(oFile == null)
 return null;
 var pattern = /(.*)\\.(.*)$/gi;
 if(typeof(oFile) == "object")
 {
 if(oFile.value == null || oFile.value == "")
 return null;
 var arr = pattern.exec(oFile.value);
 return RegExp.$2;
 }
 else if(typeof(oFile) == "string")
 {
 var arr = pattern.exec(oFile);
 return RegExp.$2;
 }
 else
 return null;
}

 

分类:  Javascript

本文转自快乐就好博客园博客,原文链接:http://www.cnblogs.com/happyday56/archive/2007/11/29/976401.html,如需转载请自行联系原作者
相关文章
|
1月前
|
JavaScript 前端开发 Java
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
本文介绍了JavaScript中常用的函数和方法,包括通用函数、Global对象函数以及数组相关函数。详细列出了每个函数的参数、返回值及使用说明,并提供了示例代码。文章强调了函数的学习应结合源码和实践,适合JavaScript初学者和进阶开发者参考。
42 2
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
|
1月前
|
前端开发 JavaScript 开发者
除了 Generator 函数,还有哪些 JavaScript 异步编程解决方案?
【10月更文挑战第30天】开发者可以根据具体的项目情况选择合适的方式来处理异步操作,以实现高效、可读和易于维护的代码。
|
2月前
|
JavaScript 前端开发
JavaScript 函数语法
JavaScript 函数是使用 `function` 关键词定义的代码块,可在调用时执行特定任务。函数可以无参或带参,参数用于传递值并在函数内部使用。函数调用可在事件触发时进行,如用户点击按钮。JavaScript 对大小写敏感,函数名和关键词必须严格匹配。示例中展示了如何通过不同参数调用函数以生成不同的输出。
|
2月前
|
存储 JavaScript 前端开发
JS函数提升 变量提升
【10月更文挑战第6天】函数提升和变量提升是 JavaScript 语言的重要特性,但它们也可能带来一些困惑和潜在的问题。通过深入理解和掌握它们的原理和表现,开发者可以更好地编写和维护 JavaScript 代码,避免因不了解这些机制而导致的错误和不一致。同时,不断提高对执行上下文等相关概念的认识,将有助于提升对 JavaScript 语言的整体理解和运用能力。
|
3月前
|
JavaScript 前端开发 安全
JavaScript函数详解
JavaScript函数的详细解析,包括函数的定义和调用方式(如一般格式、匿名函数、构造函数、自调用函数、箭头函数和严格模式)、函数参数(arguments对象、可变参数、默认参数值)、闭包的概念和应用实例。
JavaScript函数详解
|
2月前
|
JavaScript 前端开发
js教程——函数
js教程——函数
42 4
|
2月前
|
存储 JavaScript 前端开发
js中函数、方法、对象的区别
js中函数、方法、对象的区别
21 2
|
2月前
|
JavaScript 前端开发 Java
【javaScript数组,函数】的基础知识点
【javaScript数组,函数】的基础知识点
27 5
|
2月前
|
JavaScript 前端开发
Node.js 函数
10月更文挑战第5天
24 3
|
2月前
|
前端开发 JavaScript
探索JavaScript函数基础
探索JavaScript函数基础
20 3