实用的Javascript函数库
2008-09-01 14:51
274 查看
这些都是网络常用的函数,固收集起来一边做参考
function Node(parentId, id, openStatus, text, url, color){ this.parentId = parentId; // 父节点的id this.id = id; // 自身id this.href = url; this.color = color; this.openStatus = openStatus; // 当前的打开状态 this.haveChild = false; // 为了便于显示,增加了该属性,判断该节点是否有子节点,默认为没有 this.text = text; // 显示的文本信息 } // 定义一个数组用来保存所有的节点(Node)包括根节点(RootNode), 也可以用其他的方式来保存 var arrTree = new Array(); //为了在使得创建节点更方便点,定义了下面的函数: function createNode(parentId, id, openStatus, text, url, color){ // 这里检验一下输入的parentId是否存在,不存在则提示错误 // checkParent(parentId); // 检验输入的id是否已经存在,如果存在做相应的处理, 这里我就不写了 // checkId(id); // 设置该parentId有子节点 if( parentId > -1 ){ if(!arrTree[parentId].hasChild) arrTree[parentId].hasChild = true; } var node = new Node(parentId, id, openStatus, text, url, color); arrTree[arrTree.length] = node; } /*-1这里定义为根节点的父节点,不存在这样的节点,所以,判断节点的父节点为-1时,标识当前节点时父节点*/ createNode(-1/*上面的注释*/, 0/*节点id*/, true/*关闭*/, "实用的Javascript函数库", '','green'); createNode(0, 1, true, "trim函数: trim() lTrim() rTrim()", "#1"); createNode(0, 2, true, "校验字符串是否为空: checkIsNotEmpty(str)", "#2"); createNode(0, 3, true, "校验字符串是否为整型: checkIsInteger(str)", "#3"); createNode(0, 4, true, "校验整型最小值: checkIntegerMinValue(str,val)", "#5"); createNode(0, 5, true, "校验整型最大值: checkIntegerMaxValue(str,val) ", "#6"); createNode(0, 6, true, "校验整型是否为非负数: isNotNegativeInteger(str)", "#4"); createNode(0, 7, true, "校验字符串是否为浮点型: checkIsDouble(str) ", "#7", "blue"); createNode(0, 8, true, "校验浮点型最小值: checkDoubleMinValue(str,val)", "#8"); createNode(0, 9, true, "校验浮点型最大值: checkDoubleMaxValue(str,val)", "#9"); createNode(0, 10, true, "校验浮点型是否为非负数: isNotNegativeDouble(str)", "#10"); createNode(0, 11, true, "校验字符串是否为日期型: checkIsValidDate(str)", "#11"); createNode(0, 12, true, "校验两个日期的先后: checkDateEarlier(strStart,strEnd)", "#12"); createNode(0, 13, true, "校验字符串是否为email型: checkEmail(str) ", "#13", "blue"); createNode(0, 14, true, "校验字符串是否为中文: checkIsChinese(str)", "#14"); createNode(0, 15, true, "计算字符串的长度,一个汉字两个字符: realLength()", "#15"); createNode(0, 16, true, "校验字符串是否符合自定义正则表达式: checkMask(str,pat)", "#16"); createNode(0, 17, true, "得到文件的后缀名: getFilePostfix(oFile) ", "#17"); /* 这里简单的创建了一棵树,但是还没有显示,下面要做的就是怎么显示: 可能方法是有点笨拙,不要见怪 …. 显示树 // 这个思路很容易理解,就是从根节点开始, 在arrTree数组超找该根节点的子节点并显示, 这里用的是递归方式去遍历每棵树, 由于简单的结构很简单的想法,所以没有考虑算法的效率问题 */ function doRender(){ var r = appendNode(0) treeArea.appendChild(r); } // AppendNode(node), 将该节点的子节点加载到container里面, 就是div对象 function appendNode(id){ node = arrTree[id] var id = node.id; var area = document.createElement("div"); var expand = document.createElement("span"); var textNode = document.createElement("span"); var subarea = document.createElement("div"); var str = '' if( node.href ){ str += ''+ node.text + ' '; } else { if( node.color ) str += ''+ node.text+''; else str = node.text; } textNode.innerHTML = str; expand.style.fontFamily = 'Fixedsys'; expand.style.cursor = 'hand'; expand.style.color = 'red'; expand.style.padding = '5px'; expand.innerText = '-'; subarea.style.paddingLeft = '30px'; subarea.style.lineHeight = '2'; if( !node.openStatus ){ subarea.style.display = 'none'; } area.style.padding = '4px'; area.appendChild(expand); area.appendChild(textNode); area.appendChild(subarea); if(node.hasChild){ expand.innerText = '+'; if( node.openStatus ) {expand.innerText = '-'; } expand.onclick = function(){ if( subarea.style.display == '' ){ node.openStatus = false; this.innerHTML = '+'; subarea.style.display = 'none'; } else { node.openStatus = true; this.innerHTML = '-'; subarea.style.display = ''; } } for(var i=1/*因为根节点在0位置,所以从1开始查找*/; i < arrTree.length; i++ ){ if( arrTree[i].parentId == id ){ var c = appendNode(i); subarea.appendChild(c); } } } return area; // 返回div对象,里面包含了子树的信息 } doRender();
-------------- 函数检索 -------------- */ /** * 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, ""); } /********************************** Empty **************************************/ /** *校验字符串是否为空 *返回值: *如果不为空,定义校验通过,返回true *如果为空,校验不通过,返回false 参考提示信息:输入域不能为空! */ function checkIsNotEmpty(str) { if(str.trim() == "") return false; else return true; }//~~~ /*--------------------------------- Empty --------------------------------------*/ /********************************** Integer *************************************/ /** *校验字符串是否为整型 *返回值: *如果为空,定义校验通过, 返回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; }//~~~ /*--------------------------------- Integer --------------------------------------*/ /********************************** Double ****************************************/ /** *校验字符串是否为浮点型 *返回值: *如果为空,定义校验通过, 返回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; }//~~~ /*--------------------------------- Double ---------------------------------------*/ /********************************** date ******************************************/ /** *校验字符串是否为日期型 *返回值: *如果为空,定义校验通过, 返回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; }//~~~ /*--------------------------------- date -----------------------------------------*/ /********************************** email *****************************************/ /** *校验字符串是否为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; }//~~~ /*--------------------------------- email ----------------------------------------*/ /********************************** chinese ***************************************/ /** *校验字符串是否为中文 *返回值: *如果为空,定义校验通过, 返回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; } /*--------------------------------- chinese --------------------------------------*/ /********************************** mask ***************************************/ /** *校验字符串是否符合自定义正则表达式 *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; }//~~~ /*--------------------------------- mask --------------------------------------*/ /********************************** file ***************************************/ /** * 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; } |
相关文章推荐
- 实用技巧:Linux系统下VI命令快捷键集合(10)
- 13个mysql数据库的实用SQL小技巧
- iOS开发实用干货——强化你的Xcode控制台
- JDK自带的实用工具——native2ascii.exe
- JAVA 实用数组操作【转】
- 多终端访问判断设备类型(实用)
- 网页设计实用技术:JS软键盘实现(源码)
- 13个mysql数据库的实用SQL小技巧
- SQL查询语句优化的实用方法总结
- MS office系列MS office最实用的快捷键最实用的快捷键
- android实用代码段2
- git最实用命令(一)
- Dojo实用API
- Iptables 的几点实用方法
- Android Studio 实用插件
- Java咖啡馆(9)——一个压缩归档实用软件-Java基础-Java-编程开发
- CSS兼容问题实用建议
- 用PyQt做点实用工具
- 类的载入以及类是如何工作的(实用于初学)
- 软件测试用例设计实用经验之谈