盈创动力之 JS校验方法

盈创动力之 JS校验方法,第1张

var IS_NULL = 128; // 10000000var IS_FULL = 64; // 01000000var IS_HALF = 32; // 00100000var IS_ASCII = 16; // 00010000var IS_NUM = 8; // 00001000var IS_DATE = 4; // 00000100var IS_PHONE = 2; // 00000010var IS_EMAIL = 1; // 00000001var IS_NOT_NULL = 0; // 00000000//实现String的replaceAll方法String.prototype.replaceAll=function(s1,s2){ var demo=this while(demo.indexOf(s1)!=-1) demo=demo.replace(s1,s2); return demo;}//实现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,"");}/****************************************一、d出窗口*************************************************///1.日期选择窗口function fPopUpCalendarDlg(ctrlobj) { var showx = event.screenX - event.offsetX; // + deltaX; var showy = event.screenY - event.offsetY + 18; // + deltaY; var newWINwidth = 210 + 4 + 18; var retval = window.showModalDialog("../pub/CalendarDlg.htm", "", "dialogWidth:100px; dialogHeight:180px; dialogLeft:" + showx + "px; dialogTop:" + showy + "px; status:no; directories:yes;scrollbars:no;Resizable=no; "); if (retval != null) { retval = retval.replace(/\//g, "-");ctrlobj.value = retval; }}/****************************************二、控制键盘录入*************************************************/

//1.控制键盘输入,只允许数字键录入整数function intOnly() { if (!(window.event.keyCode >= 48 && window.event.keyCode <= 57 ||window.event.keyCode==13 //回车符 )) {window.event.keyCode = 0; alert("请输入整数数字!"); }}//2.控制键盘输入,只允许数字键录入整数//和intOnly()区别:输入完成焦点离开后判断数字是否合法function intOnly2(param) { var reg=/^([0-9]*)$/; var flag = reg.test(param.value); if(!flag){ alert("请输入整数数字!");param.value=""; }}

//1.控制键盘输入,只允许数字键录入小数和整数function numberOnly() { if (!(((window.event.keyCode >= 48) && (window.event.keyCode <= 57)) || (window.event.keyCode == 13) || (window.event.keyCode == 46))) { window.event.keyCode = 0; alert("请输入数字!"); }}//2.控制键盘输入,只允许数字键录入小数和整数//和numberOnly()区别:输入完成焦点离开后判断数字是否合法function numberOnly2(param) { var reg=/^([0-9]+(\.?[0-9]+)?)$/; var flag = reg.test(param.value); if(!flag){ if(param.value!=""){ alert("请输入数字!");param.value=""; } }}

//1.控制键盘输入时只能输入数字和小数点function floatOnly() { if (!(((window.event.keyCode >= 48) && (window.event.keyCode <= 57)) || (window.event.keyCode == 13) || (window.event.keyCode == 46))) { window.event.keyCode = 0; alert("输入有误,请输入数字!"); }}

//2.控制键盘输入时只能输入数字和小数点//和floatOnly()区别:输入完成焦点离开后判断数字是否合法function floatOnly2(param) { var reg=/^([0-9]+(\.?[0-9]+)?)$/; var flag = reg.test(param.value); if(!flag){ if(param.value!=""){ alert("输入有误,请输入数字!");param.value=""; } }}

//控制键盘输入时只能输入数字和‘-‘,用于限制电话号码的输入function phoneOnly() { if (!(window.event.keyCode >= 48 && window.event.keyCode <= 57 || window.event.keyCode == 45 || window.event.keyCode == "\uff0d" ||window.event.keyCode==13 //回车符)) {alert("电话号码输入有误,请输入数字!");window.event.keyCode = 0; }}//控制键盘输入时只能输入数字和‘-‘,用于限制电话号码的输入//和phoneOnly()区别:输入完成焦点离开后判断数字是否合法function phoneOnly2(param) { var reg=/^([0-9]+(\-?[0-9]+)?)$/; var flag = reg.test(param.value); if(!flag){ if(param.value!=""){ alert("电话号码输入有误,请输入数字!");param.value=""; } }}

/***************************************///检查<html:file><input type="file">中地址所指文件是否是图片类型function isImage(obj) { var str = obj.value; var temp = str.indexOf("."); if (temp > 0) { str = str.substring(temp + 1).toLowerCase(); var myTypes = new Array("gif", "jpg", "jpeg", "png"); for (i = 0; i < myTypes.length; i++) { if (str == myTypes[i]) { return; } } alert("\u8bf7\u9009\u62e9\u683c\u5f0f\u4e3agif,jpg,jpeg,png\u7684\u56fe\u7247"); obj.select(); }}/****************************************三、数字的格式化 *** 作函数*************************************************///取浮点数,可以定义小数点后精确的位数,并且四舍五入。function getFloat(number, reserve) { var index = number.indexOf("."); if (index == -1) { return number; } else { var index = index + reserve + 1; if (index >= number.length) { return number; } else { var temp = number.charAt(index); number = number.substring(0, index); if (parseInt(temp) < 5) { return number; } else { for (var i = index - 1; i >= 0; i--) {if (number.charAt(i) == ".") { continue; } var value = parseInt(number.charAt(i)); value++; if (value != 10) { number = replace(number, i, value); return number; } else { number = replace(number, i, "0"); if (i == 0) { number = "1" + number; } } } return number; } } }}function replace(number, i, value) { var newnumber = number.substring(0, i) + value; newnumber = newnumber + number.substring(i + 1, number.length); return newnumber;}/****************************************四、字符串的格式化 *** 作函数*************************************************///1.子字符串替换function replaceStr(str, sFnd, sRep) { var sTmp = ""; var endIndex = 0; var beginIndex = 0; var len = sFnd.length; while (endIndex >= 0) { var endIndex = str.indexOf(sFnd, beginIndex); if (endIndex >= 0) { sTmp += str.substring(beginIndex, endIndex) + sRep; beginIndex = endIndex + len; } else { if (beginIndex >= 0) { sTmp += str.substring(beginIndex); break; } } } return sTmp;}//2.单双引号替换(基于子字符串替换函数)function replaceCommas(str) { if (str == "") { return str; } str = replaceStr(str, "‘", "‘"); //str = replaceStr(str, ‘"‘, ‘"‘); return str;}

//3.去掉字符串中的给定字符function removeChar(str, c) { if (str == null || str == "") { return str; } var i = str.indexOf(c); while (i >= 0) { str = str.substring(0, i) + str.substring(i + 1, str.length); i = str.indexOf(c); } return str;}

//4.验证strings中是否包含string,其中strings是一‘,‘为分隔符的字符串,例:"a,ab,cd"function isContainString(strings, string){ var array = strings.split(","); if ("" == string) return false; if (array.length == 0) return false; for (var i = 0; i < array.length; i++) { if(string == array[i]) { return true; } } return false;}

/****************************************五、日期的格式化 *** 作函数*************************************************///1.年月日组合成格式化的字符串function formatDate(sYear, sMonth, sDay) { if (sMonth.length == 1) { sMonth = "0" + sMonth; } if (sDay.length == 1) { sDay = "0" + sDay; } return sYear + sMonth + sDay;}//2.日期型转换为格式化的字符串function convDate(sDate, sSep) { var pos = 0; var str = sDate; var len = str.length; if ((len < 8) || (len > 10)) { return str; } else { if (str.indexOf(sSep) == 4) { pos = str.indexOf(sSep, 5); if (pos == 6) { if (len == 8) { return str.substring(0, 4) + "0" + str.substring(5, 6) + "0" + str.substring(7, 8); } else { return str.substring(0, 4) + "0" + str.substring(5, 6) + str.substring(7, 9); } } else { if (pos == 7) { if (len == 9) { return str.substring(0, 4) + str.substring(5, 7) + "0" + str.substring(8, 9); } else { return str.substring(0, 4) + str.substring(5, 7) + str.substring(8, 10); } } else { return str; } } } else { return str; } }}//3.判断是否为闰年function checkLeapYear(year) { if (((year % 4 == 0) && (year % 100 != 0)) || (year % 400 == 0)) { return true; } return false;}//4.获得格式化的系统时间function getSysDate() { var today = new Date(); var nYear = today.getYear(); var nMonth = today.getMonth() + 1; var nDay = today.getDate(); var sToday = ""; if (nYear < 1000) { sToday += "" + (1900 + nYear); } else { sToday += nYear; } if (nMonth < 10) { sToday += "0" + nMonth; } else { sToday += nMonth; } if (nDay < 10) { sToday += "0" + nDay; } else { sToday += nDay; } return sToday;}//5.比较两个日期的大小//dateStr1 >,=,< dateStr2 return 1,0,-1function compareDateStr(dateStr1, dateStr2) { if (dateStr1.indexOf("/") > 0) { dateStr1 = convDate(dateStr1, "/"); } else { if (dateStr1.indexOf("-") > 0) { dateStr1 = convDate(dateStr1, "-"); } } if (dateStr2.indexOf("/") > 0) { dateStr2 = convDate(dateStr2, "/"); } else { if (dateStr2.indexOf("-") > 0) { dateStr2 = convDate(dateStr2, "-"); } } //dateStr2 = convDate(dateStr2, "/"); if (dateStr1 > dateStr2) { return 1; } else { if (dateStr1 == dateStr2) { return 0; } else { return -1; } } return dateStr1;}//6.判断是否小于当前时间function checkBeforeDate(str) { //统一格式为20100803 if (str.indexOf("/") > 0) { str = convDate(str, "/"); } else { if (str.indexOf("-") > 0) { str = convDate(str, "-"); } } if (str.length == 6) { str += "01"; } //开始比较 if (str >= getSysDate()) { return false; } return true;}//7.判断是否等于当前时间function checkIsToday(str) { str = convDate(str, "/"); if (str.length == 6) { str += "01"; } if (str == getSysDate()) { return true; } else { return false; }}//8.判断是否大于当前时间function checkAfterDate(str) { str = convDate(str, "/"); if (str.length == 6) { str += "01"; } if (str <= getSysDate()) { return false; } return true;}//比较两个时间大小function compareDate(fromDate, toDate) { if (checkDate(fromDate) != true) { return false; } if (checkDate(toDate) != true) { return false; } if (fromDate.indexOf("/") > 0) { fromDate = convDate(fromDate, "/"); } else { if (fromDate.indexOf("-") > 0) { fromDate = convDate(fromDate, "-"); } } if (toDate.indexOf("/") > 0) { toDate = convDate(toDate, "/"); } else { if (toDate.indexOf("-") > 0) { toDate = convDate(toDate, "-"); } } if ((fromDate.length != 8) || !checkNumber(fromDate) || (toDate.length != 8) || !checkNumber(toDate)) { return false; } if (fromDate <= toDate) { return true; } else { return false; }}

/****************************************五、表单值的格式化 *** 作*************************************************///1.上传文件时取得表单的上传路径中的文件名function getFileName(fullpath) { var platform = navigator.platform; var fileseperator = (platform.indexOf("Win") == -1) ? "/" : "\"; var idx = fullpath.lastIndexOf(fileseperator); if (idx == -1) { return fullpath; } else { if (idx >= fullpath.length - 1) { return ""; } else { return fullpath.substring(idx + 1); } }}//2.去掉FORM中所有TEXT和TEXTAREA表单的值两边的空格function trimItems(oFrm) { var i = 0; var type = ""; for (i = 0; i < oFrm.elements.length; i++) { type = oFrm.elements[i].type; if ((type == "text") || (type == "textarea")) { oFrm.elements[i].value = oFrm.elements[i].value.trim(); } }}/****************************************六、提交前的表单值检查*************************************************///1.在删除 *** 作时选择复选框function isSelected() { for (var i = 0; i < document.all.length; i++) { if (document.all[i].tagName.toUpperCase() == "INPUT") { var tmp = document.all[i].type.toUpperCase(); var name = document.all[i].name; if ((tmp == "CHECKBOX") && (document.all[i].checked == true) && (name == "selection" || name == "selected")) { return true; } } } return false;}//2.检查表单的值是否为空,是否符合最大最小长度限制var MSG_CHECK_SUCCESS = "Check Success";function checkItem(sCheck, nMinLen, nMaxLen, chkFlg) { var strLen = 0; if ((sCheck == null) || (sCheck == "")) { if (((chkFlg & 128) == 128) || ((chkFlg & 0) == 0)) { return "\u662f\u5fc5\u987b\u8f93\u5165\u7684\u9879\u76ee"; } else { return MSG_CHECK_SUCCESS; } } if ((nMinLen > 0) || (nMaxLen > 0)) { strLen = getLength(sCheck); if (nMinLen > 0) { if (nMinLen == nMaxLen) { if (strLen != nMinLen) { if ((chkFlg & 8) == 8) { return "\u7684\u957f\u5ea6\u5fc5\u987b" + nMinLen + "\u5b57\u8282"; } else { return "\u7684\u957f\u5ea6\u5fc5\u987b" + nMinLen + "\u5b57\u8282"; } } } else { if (strLen < nMinLen) { if ((chkFlg & 8) == 8) { return "\u4e0d\u662f\u6570\u5b57"; } else { return "\u8fc7\u4e8e\u77ed\u5c0f\uff0c\u6700\u5c0f\u957f\u5ea6\u4e3a" + nMinLen + "\u5b57\u8282"; } } } } if (nMaxLen > 0) { if (strLen > nMaxLen) { return "\u8d85\u8fc7\u4e86\u6700\u5927\u957f\u5ea6" + nMaxLen + "\u5b57\u8282"; } } } if ((chkFlg & 16) == 16) { if (!checkASCII(sCheck)) { return "\u4e0d\u6b63\u786e"; } } if ((chkFlg & 8) == 8) { if (!checkNumber(sCheck)) { return "\u662f\u6570\u5b57\u9879\u76ee"; } } if ((chkFlg & 4) == 4) { if (!checkDate(sCheck)) { return "\u662f\u65e5\u671f\u9879\u76ee"; } } if ((chkFlg & 2) == 2) { if (!checkPhone(sCheck)) { return "\u4e0d\u6b63\u786e"; } } if ((chkFlg & 1) == 1) { if (!checkEmail(sCheck)) { return "\u4e0d\u6b63\u786e"; } } return MSG_CHECK_SUCCESS;}function check(sItemName, sCheck, nMinLen, nMaxLen, chkFlg) { sRet = checkItem(sCheck, nMinLen, nMaxLen, chkFlg); if (sRet != MSG_CHECK_SUCCESS) { sErr += sItemName + sRet + "\n"; return false; } return true;}//3.检查电子邮件表单的格式是否正确function checkEmail(str) { var i; var len = str.length; var aPos = str.indexOf("@"); var dPos = str.indexOf("."); var aaPos = str.indexOf("@@"); var adPos = str.indexOf("@."); var ddPos = str.indexOf(".."); var daPos = str.indexOf(".@"); var chkStr = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890-_@."; if ((aPos <= 0) || (aPos == len - 1) || (dPos == len - 1) || (adPos > 0) || (daPos > 0) || (str.charAt(len - 1) == "@") || (str.charAt(len - 1) == ".") || (aaPos > 0) || (ddPos > 0)) { return false; } if (str.indexOf("@", aPos + 1) > 0) { return false; } for (i = 0; i < len; i++) { if (chkStr.indexOf(str.charAt(i)) < 0) { return false; } } return true;}//4.检查电话号码表单的格式是否正确function checkPhone(str) { var i = str.indexOf("--"); var len = str.length; if (i >= 0) { return false; } i = str.indexOf("-"); if ((i == 0) || (i == len - 1)) { return false; } else { if (i > 0) { i = str.lastIndexOf("-");if (i == len - 1) { return false; } str = removeChar(str, "-"); } } if (!checkNumber(str)) { return false; } else { return true; }}//5.检查是否为英文字母function checkEngNum(str) { if (str == null || str == "") { return true; } var c = new RegExp(); c = / ^ [\d | a - zA - Z] + $ /; if (c.test(str)) { return true; } else { return false; }}//6.检查是否为数字型元素function checkNumber(str) { var i; var len = str.length; var chkStr = "1234567890"; if (len == 1) { if (chkStr.indexOf(str.charAt(i)) < 0) { return false; } } else { if ((chkStr.indexOf(str.charAt(0)) < 0)) { return false; } for (i = 1; i < len; i++) { if (chkStr.indexOf(str.charAt(i)) < 0) { return false; } } } return true;}//7.检查是否为浮点型元素function checkFloat(str) { var i; var len = str.length; var chkStr = "1234567890."; if (len == 1) { if (chkStr.indexOf(str.charAt(i)) < 0) { return false; } } else { //if ((chkStr.indexOf(str.charAt(0)) < 0) || (str.charAt(0) == "0")) { if ((chkStr.indexOf(str.charAt(0)) < 0)) { return false; } for (i = 1; i < len; i++) { if (chkStr.indexOf(str.charAt(i)) < 0) { return false; } } } return true;}//8.检查是否为日期function checkDate(str) { var index = str.indexOf("-"); var subIndex = str.indexOf("-",index+1); if(str.substring(parseInt(subIndex)+1,str.length).length>2){ return false; } if(str.indexOf("-")==-1){ return false; } str = convDate(str, "-"); if ((str.length != 8) || !checkNumber(str)) { return false; } var year = str.substring(0, 4); var month = str.substring(4, 6); var day = str.substring(6, 8); dayOfMonth = new Array(31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31); if ((month < 1) || (month > 12)) { return false; } if ((day < 1) || (day > dayOfMonth[month - 1])) { return false; } if (!checkLeapYear(year) && (month == 2) && (day == 29)) { return false; } //sqlserver中日期不能小于1753年,故在此对日期加以限定 if(year<1800){ return false; } return true;}

function checkInputDate(object){ changeDateFormate(object); if(object.value!=""&&checkDate(object.value)==false){ alert("日期输入不合法,请重新输入!");object.focus(); object.select(); }}//将日期格式统一转换为十位YYYY-MM-DDfunction changeDateFormate(object){ var str=object.value; str=str.replaceAll("/","-"); if(object.value.length==8){ str=str.substring(0,4)+"-"+str.substring(4,6)+"-"+str.substring(6,8); } object.value=str;}/****************************************七、子窗口的d出与关闭*************************************************/var childWindow = null;var fatherWindow = null;var form = null;

// 打开子窗口,在打开之前定义父窗口的名字function openNew(URL, Width, Height) {

// window.name = "fatherWindow"; closeChildNew(); showx = event.screenX - event.offsetX - Width; // + deltaX; showy = event.screenY - event.offsetY - Height - 30; // + deltaY; var features = "width = " + Width + ",height = " + Height + ",left = " + showx + ",top = " + showy + ",directories = no, localtion = no, menubar = no, status = yes, toolbar = no,scrollbars = yes, resizeable = no"; childWindow = window.open(URL, "", features);}// 如果已经有子窗口打开,则关闭之function closeChildNew() { if (childWindow && childWindow.open && !childWindow.closed) { childWindow.close(); }}

// 关闭子窗口的同时,进行提交,并将提交之后的得页面转到父窗口,关闭子窗口// 这里本应该是使用同一个函数,但是时间有点急,就function closeChildWindow(fatherForm, childForm, actionType) { childForm.actionType.value = actionType; childForm.target = "mainFrame"; childForm.submit(); window.close(); return true;}function closeChildWindowNew(childForm, actionType) { childForm.actionType.value = actionType; childForm.target = "fatherWindow"; childForm.submit(); window.close(); return true;}/* SelectAllOptions ***********************************************************/// set all options to selected/******************************************************************************/function SelectAllOptions(theSelect) { for (var i = 0; i < theSelect.options.length; i++) { theSelect.options[i].selected = true; }}//改变选中行的css;author:lithlin for rdms only!function changeCss(CB, className) { if (CB.checked) { while (CB.tagName != "TR") { CB = CB.parentElement; } CB.className = "ListTrLight"; } else { while (CB.tagName != "TR") { CB = CB.parentElement; } CB.className = className; }}// function MoveAllOptionsTo(fromSelect, toSelect) { var myform = document.expertslistform; //removeAllItem(toSelect); for (i = 0; i < fromSelect.options.length; i++) { var name = fromSelect.item(i).text; var newOpt = new Option(name, fromSelect.item(i).value); toSelect.add(newOpt); }}function removeAllItem(from) { for (i = from.options.length - 1; i >= 0; i--) {from.remove(i); }}//在两个选择框中移动数据function MoveOptionsTo(fromSelect, toSelect) { var myform = document.expertslistform; for (i = 0; i < fromSelect.options.length; i++) { // alert(fromSelect.options.length); if (fromSelect.options(i).selected == true) { j = toSelect.options.length - 1; // alert(toSelect.options.length); for (; j >= 0; j--) {if (fromSelect.item(i).value == toSelect.item(j).value) { break; } } if (j < 0) { var name = fromSelect.item(i).text; var newOpt = new Option(name, fromSelect.item(i).value); toSelect.add(newOpt); } } }}//移走某个多选框中的数据function removeItem(from) { for (i = from.options.length - 1; i >= 0; i--) {if (from.options(i).selected == true) { from.remove(i); } }}//上移或者下移某个多选框的数据function upOrDownItem(form,flag) { var j=0; for (i =0; i < form.options.length; i++) { if (form.options(i).selected == true) { if(flag=="up"){ j=i-1; if(j<0){ j=form.options.length-1; } }else if(flag=="down"&&i<form.options.length-1){ j=i+1; } if(i!=j){ var value=form.options(i).value; var text=form.options(i).text; form.options(i).value=form.options(j).value; form.options(i).text=form.options(j).text; form.options(i).selected=false; form.options(j).value=value; form.options(j).text=text; form.options(j).selected=true; return; } } }}//===============全选按钮 *** 纵所有多选框==========================================function checkAll() { var state = document.forms[0].selectstate.value; var j = 0; for (var i = 0; i < document.forms[0].elements.length; i++) { var e = document.forms[0].elements[i]; if ((!e.disabled) && e.name == "selected") { e.checked = state; j++; } } if (state == "on") { document.forms[0].selectstate.value = ""; } else { document.forms[0].selectstate.value = "on"; } if(state!="on"){ MM_showHideLayers(‘allselect‘,‘‘,‘hide‘,"0"); }else{ MM_showHideLayers(‘allselect‘,‘‘,‘show‘); }}function MM_showHideLayers() { document.forms[0].selectedDataScope.value=""; var i,p,v,obj,args=MM_showHideLayers.arguments; for (i=0; i<(args.length-2); i+=3) with (document) if (getElementById && ((obj=getElementById(args[i]))!=null)) { v=args[i+2]; if (obj.style) { obj=obj.style; v=(v==‘show‘)?‘visible‘:(v==‘hide‘)?‘hidden‘:v; } obj.visibility=v; }}function MM_showHideLayers(act1,act2,act3,act4) { if(document.forms[0].selectedDataScope!=undefined){ document.forms[0].selectedDataScope.value=act4; } var i,p,v,obj,args=MM_showHideLayers.arguments; for (i=0; i<(args.length-2); i+=3) with (document) if (getElementById && ((obj=getElementById(args[i]))!=null)) { v=args[i+2]; if (obj.style) { obj=obj.style; v=(v==‘show‘)?‘visible‘:(v==‘hide‘)?‘hidden‘:v; } obj.visibility=v; }}//判断第1个数字是否大于第2个数字function oneBigThanTwo(one,two){ var temp1=parseFloat(one); var temp2=parseFloat(two); return temp1>temp2?true:false;}

//将值转化成Float型function turnToFloat(name) { trimValue(name); var value = document.all[name].value; value = getFloat(value, 2); document.all[name].value = value;}

//对数字型数据值进行整理function trimValue(name) { var value = document.all[name].value; if (value == "" || parseFloat(value) == 0) { document.all[name].value = 0; return; } //去掉开头的0 for (var i = 0; i < value.length; i++) { if (value.charAt(i) == 0) { continue; } else { value = value.substring(i); break; } } document.all[name].value = value;}

//百分比计算,结果保留小数点两位function getRatio(num1, num2) { if (num2 == 0) { return 0; } var result = num1 / num2 * 100; return getFloat(result + "", 2);}/*给出起始日期的年月日year,month,day及此后的天数days,算出这days天中的工作日数目*/function getWorkDay(year, month, day, days) { date = new Date(); date.setFullYear(year, month, day); startWeekDay = date.getDay(); yushu = days % 7; weekNum = (days - yushu) / 7; if ((startWeekDay == 1) || (startWeekDay + yushu == 8)) { total = weekNum * 2 + 1; } else { if (startWeekDay + yushu > 8) { total = weekNum * 2 + 2; } else { total = weekNum * 2; } } return days - total;}

//判断页面输入内容是否超过字数限制function checkLimit(field, limit) { var fieldLength = strlength(field.value); var newLimit = limit * 2; if (fieldLength > newLimit) { return false; } else { return true; }}

//计算字符长的字节长度function strlength(str) { var l = str.length; var n = l; for (var i = 0; i < l; i++) { if (str.charCodeAt(i) < 0 || str.charCodeAt(i) > 255) { n++; } } return n;}function printDocument() { window.open("../pub/print.jsp");}function printReportForms() { window.open("../pub/printReport.htm");}//改变页面查询类型 function changeSearchMode() { if (document.all["queryBean.searchMode"].value == "a") { document.all["simple"].style.display = "none"; //document.getElementById("simpleHead").setAttribute("background","../images/searchbg01.gif"); document.all["advance"].style.display = ""; //document.getElementById("advanceHead").setAttribute("background","../images/searchbg002.gif"); } else { document.all["simple"].style.display = ""; //document.getElementById("simpleHead").setAttribute("background","../images/searchbg002.gif"); document.all["advance"].style.display = "none"; //document.getElementById("advanceHead").setAttribute("background","../images/searchbg01.gif"); } //如果更多查询存在 if(document.all["more"]!=null){ if(document.all["queryBean.defaultSearchFlag"].value=="1"){ document.all["more"].style.display="none"; } else{ document.all["more"].style.display="block"; } }}function checkAuthorNum(obj){ if("edit"==document.all[‘pageType‘].value){ var newValue = obj.value; var oldValue = document.all[‘authorNum‘].value; if(parseFloat(oldValue)>parseFloat(newValue)){ alert(‘作者人数必须大于最大作者署名顺序!‘);obj.value=oldValue; this.focus(); } }}function convert(act){ var selectedStyle="url(../images/tabright1_top.gif) no-repeat right top"; var unSelectedStyle="url(../images/tabright1_bottom.gif) no-repeat right top"; if(act=="simple"){ document.all["queryBean.searchMode"].value="s"; document.getElementById("simple_search").style.background=selectedStyle; document.getElementById("advance_search").style.background=unSelectedStyle; }else if(act=="advance"){ document.all["queryBean.searchMode"].value="a"; document.getElementById("simple_search").style.background=unSelectedStyle; document.getElementById("advance_search").style.background=selectedStyle; } changeSearchMode();}//改变查询页面提交方式function changeSubmitType() { var submitType; for (var i = 0; i < document.all["submitType"].length; i++) { if (document.all["submitType"][i].checked) { submitType = document.all["submitType"][i].value; } } if (submitType == "exportExcel") { document.all["exportExcel"].style.display = "block"; document.all["statistic"].style.display = "none"; } else { if (submitType == "statistic") { document.all["exportExcel"].style.display = "none"; document.all["statistic"].style.display = "block"; } else { if (submitType == "search") { document.all["exportExcel"].style.display = "none"; document.all["statistic"].style.display = "none"; } } }}//清空查询页面function searchFormClear(){ var i = 0; var type = ""; for (i = 0; i <document.forms[0].elements.length; i++) { var ele=document.forms[0].elements[i]; type = document.forms[0].elements[i].type; if ((type == "text") || (type == "textarea")) { ele.value =""; } else if(type=="select-one"){ ele.options[0].selected=true; } else if(type == "radio"){ //查询页面清空时,单选框选中“所有”选项if(ele.value!=""){ ele.checked=false; } else{ ele.checked=true; } }else if(type=="checkbox"){ ele.checked=false; } }}//返回列表页面function backListPage(){ document.all["actionType"].value = "list"; document.forms[0].submit();}

//通用提交验证方法function onsubmit() { var property; var message; var dateProperty; var dateMessage; //1.对form中的text和textarea对象进行trim处理 trimItems(document.forms[0]); //2.判断必填项是否有数据 if (propertys!= null&&propertys!= ""&&msg!=null&&msg!="") { property = propertys.split(","); message = msg.split(","); for (i = 0; i < property.length; i++) { //判断字段是否在页面存在,存在时校验必填if(document.all[property[i]]!=null){ var eleObj = document.all[property[i]]; var dateType = elemGetAttribute(eleObj,"dataType"); var propertyValue=getPropertyValue(property[i]); var theResulet = checkItem(propertyValue, 0, 0, IS_NOT_NULL); if (theResulet == MSG_CHECK_SUCCESS) { if(dateType ==‘decimal‘){ var intValue = parseFloat(propertyValue); if(intValue < 0){ alert(message[i]+"应大于或者等于0"); eleObj.focus(); return false; } } } else { alert(message[i] + theResulet); //转移焦点到字段内if (document.all[property[i]].type == "text"|| //文本框document.all[property[i]].type == "textarea"|| //文本区document.all[property[i]].type == "select-one" //下拉框) {document.all[property[i]].focus(); } else if($("input[name="+property[i]+"]").attr("type")=="radio"){ //单选按钮$("input[name="+property[i]+"]")[0].focus(); } return false; break; } } } } if (datePropertys!= null&&datePropertys!= ""&&dateMsg!=null&&dateMsg!="") { dateProperty = datePropertys.split(","); dateMessage = dateMsg.split(","); for (i = 0; i < dateProperty.length; i++) { var dateObj = $("input[name=‘"+dateProperty[i]+"‘]"); //判断改字段信息是否在页面存在if(dateObj!=null&&dateObj.val()){ //日期字段如果有值,校验其合法性if(!dateObj.attr("disabled")&&dateObj.val().length>0){ var theResulet = checkDate(dateObj.val()); if (theResulet) { } else { alert(dateMessage[i] + "不是合法的日期形式");dateObj.focus(); dateObj.select(); return false; break; } } } } } //3.对form中的text和textarea对象 进行长度检查 if(!checkLen()){ return false; } return true;}

//对页面为text/textarea对象进行长度检查function checkLen(){ var nodeList = document.getElementsByTagName("input"); for(var i = 0; i < nodeList.length;i++){ if(nodeList[i].getAttribute("type") != "hidden"){ var maxLength = nodeList[i].getAttribute(‘maxLength‘); //仅针对存在maxLength属性的控件进行控制if(maxLength!=null){ var str = nodeList[i].value; var len = 0; for(var j=0;j<str.length;j++) { char = str.charCodeAt(j); if(!(char>255)) { len = len + 1; } else { len = len + 2; } } if(len > maxLength){ var tt = nodeList[i].parentNode.previousSibling.innerHTML; var title = tt.replaceAll(":",""); alert(title+":最多可输入"+Math.floor(maxLength/2)+"个汉字或"+maxLength+"个英文字符!"); nodeList[i].focus(); return false; } } } } return true;}

//根据属性名得到其页面上的值function getPropertyValue(propertyName){ var propertyValue=""; //如果是单选框 if(document.all[propertyName].length!=null&&document.all[propertyName][0].type=="radio"){ for(var i=0;i<document.all[propertyName].length;i++){ if(document.all[propertyName][i].checked==true) propertyValue = " "; } } //文本框、文本区或下拉框 else if(document.all[propertyName].type=="select-one"){ propertyValue=$("select[name=‘"+propertyName+"‘]").val(); }else{ propertyValue=document.all(propertyName).value; } return propertyValue;} //删除和重新上传附件时删除原附件方法 往后台提交一次,将原附件id设置为0,保存时从数据库删除function deleteFile(){ document.forms[0].actionType.value="removeFile"; document.forms[0].submit(); } var xmlHttp; /*****************************************************以下 *** 作,完成页面生成下拉框的功能**************************************/ //创建xmlHttp对象function createXMLHttpRequest(){ //如果浏览器支持ActiveX if(window.ActiveXObject){ xmlHttp=new ActiveXObject("Microsoft.XMLHTTP"); } //如果浏览器支持对象XMLHttpRequest else if(window.XMLHttpRequest){ xmlHttp=new XMLHttpRequest(); } } /**自动生成二级下拉框以达到局部刷新attribName1: 例如:“project.projectTypeId” attribName2: 例如:“project.projectSubTypeId” **/function generateOption(attribName1,attribName2){ var selfName=convertStandardId(attribName1); if(document.all[selfName].value){ var attribName1Value = document.all[selfName].value; }else{ var attribName1Value = $("input[name="+selfName+"]:checked").val(); } //创建xmlHttpRequest对象createXMLHttpRequest(); //请求地址var url="option.option?attribName1="+attribName1+"&attrib1Value="+attribName1Value+"&attribName2="+attribName2+"&timeStamp="+new Date().getTime(); xmlHttp.open("GET",url,false); xmlHttp.onreadystatechange=regerateOptions; xmlHttp.send(null); } /**自动生成二级下拉框以达到局部刷新 带2个参数的下拉框attribName1: 例如:“person.subjectId” attribName3: 例如:“person.subject2Id” attribName2: 例如:“person.subject3Id” **/function generateTwoParamsOption(attribName1,attribName3,attribName2){ var selfName=convertStandardId(attribName1); var selfName3=convertStandardId(attribName3); var attribName1Value = document.all[selfName].value; var attribName3Value = document.all[selfName3].value; //创建xmlHttpRequest对象createXMLHttpRequest(); //请求地址var url="option.option?attribName1="+attribName1+"&attrib1Value="+attribName1Value+"&attribName3="+attribName3+"&attribName3Value="+attribName3Value+"&attribName2="+attribName2+"&timeStamp="+new Date().getTime(); xmlHttp.open("GET",url,true); xmlHttp.onreadystatechange=regerateOptions; xmlHttp.send(null); } /**根据新增还是查询转换成标准id号: 例如:“project.projectTypeId” 新增时会变成“bean.projectTypeId”查询时会变成“@projectTypeId”displayId 原始的Id 如:“project.projectTypeId” */function convertStandardId(sourceValue){ var actionType=document.forms[0].actionType.value; var selfName=""; if("batchUpdateForm"==document.forms[0].name){//批量修改特殊处理var operateId = document.forms[0].operateId.value;//获得 *** 作列的编号selfName="@"+sourceValue.substring(sourceValue.indexOf(".")+1)+"_"+operateId; }else if("integratedSearchForm"==document.forms[0].name){//综合查询特殊处理selfName="@"+sourceValue; }else{ if("initSearch"==actionType||"popSearch"==actionType||"search"==actionType||actionType.indexOf("statistic")>=0||"saveStaticFilterfields"==actionType ||"popQueryOptions"==actionType||actionType.indexOf("Search")>=0||"popCompleteQueryOptions"==actionType){ selfName="@"+sourceValue.substring(sourceValue.indexOf(".")+1); }else{ selfName="bean"+sourceValue.substring(sourceValue.indexOf(".")); } } return selfName; } /** selfName 自身对象名称tgtName 目标对象名称categoryName 目标对象对应的常量名checkRight 是否检查权限**/function generateOptionWithRight(modelName,selfName,tgtName,categoryName,checkRight){ var selfName=convertStandardId(attribName1); var attribName1Value = document.all[selfName].value; //创建xmlHttpRequest对象createXMLHttpRequest(); //请求地址var url="option.option?checkRight=true&attribName1="+attribName1+"&attrib1Value="+attribName1Value+"&attribName2="+attribName2+"&timeStamp="+new Date().getTime(); xmlHttp.open("GET",url,true); xmlHttp.onreadystatechange=regerateOptions; xmlHttp.send(null); } //处理请求结果function regerateOptions(){ if(xmlHttp.readyState==4){ if(xmlHttp.status==200){ var mes=xmlHttp.responseXML; var targetName=mes.getElementsByTagName("target")[0].firstChild.nodeValue; targetName=convertStandardId(targetName); var mb = document.getElementsByName(targetName)[0]; //如果目标对象存在,对其赋值if(mb){ cleanList(mb); var options=mes.getElementsByTagName("option"); for(i=0;i<options.length;i++){ var option=document.createElement("option"); if(options[i].childNodes[0].firstChild!=null){ option.setAttribute("value",options[i].childNodes[0].firstChild.nodeValue); }else{ option.setAttribute("value",""); } option.appendChild(document.createTextNode(options[i].childNodes[1].firstChild.nodeValue)); mb.appendChild(option); } } } } } //清除下拉框中的值 function cleanList(listObject){ while(listObject.hasChildNodes()){ listObject.removeChild(listObject.firstChild); } }/*****************************************************以下 *** 作,完成页面的某个区域刷新功能**************************************//**通过Ajax生成区域代码,实现局部刷新pageAreaId 区域区 "detail" attributeName 触发事件的属性名 例如:project.projectTypeId @author zjh*/function generateArea(pageAreaId,attribName){ //查询:只能用pop() var actionType=document.forms[0].actionType.value; if("initSearch"==actionType||"popSearch"==actionType||"search"==actionType||actionType.indexOf("statistic")>=0||"saveStaticFilterfields"==actionType ||"popQueryOptions"==actionType||actionType.indexOf("Search")>=0||"popCompleteQueryOptions"==actionType){ return pop(); } //创建xmlHttpRequest对象createXMLHttpRequest(); //属性值var thisAttribName="bean".concat(attribName.substring(attribName.indexOf("."))); var attribValue=document.all[thisAttribName].value; //请求地址var url="area.area?pageAreaId="+pageAreaId+"&attribName="+attribName+"&attribValue="+attribValue; //保证同步执行xmlHttp.open("GET",url,true); //回调方法,获得状态xmlHttp.onreadystatechange=function(){ areawrite(pageAreaId); //区域刷新后重新获取焦点(获取焦点为触发刷新事件的控件)document.all[thisAttribName].focus(); }; xmlHttp.send(null); }/**回调方法,并将内容写回客户端pageAreaId 页面显示的区域*/function areawrite(pageAreaId){ if(xmlHttp.readyState==4){ if(xmlHttp.status==200){ var mes=xmlHttp.responseText; document.getElementById(pageAreaId).innerHTML=mes; } } }/*****************************************************以上 *** 作,完成页面的某个区域刷新功能**************************************/

/**删除表格的行pageAreaId TBoby行的编号*/function deleteRows(pageAreaId){ var tt=document.getElementById(pageAreaId); var n=tt.rows.length;//行长度 for(i=0;i<n;i++){ tt.deleteRow(0);//删除某一行 }}

/** * 校验对象objectName的属性attribName1、和属性attribName2在数据库中是否存在重名,currentId用于编辑查询时排除对象自身* objectName 对象名* attribName1 属性名* attribName2 属性名2 * forceFlag 强制检测标识,如果为true,重名不能提交,否则仅提醒重名*/function checkTwoAttribSameName(objectName,attribName1,attribName2,forceFlag){ // 只有在新增时校验重名//if(document.all["actionType"].value=="add"){ //创建xmlHttpRequest对象createXMLHttpRequest(); var attribValue1=document.all["bean."+attribName1].value; var attribValue2=document.all["bean."+attribName2].value; var currentId=document.all["bean.id"].value; //只有属性值长度大于零时进行校验重名if(attribValue1.length>0){ //请求地址var url="eplugger.checkSameName?objectName="+objectName+"&attribName="+attribName1+"&attribValue="+attribValue1 +"&attribName2="+attribName2+"&attribValue2="+attribValue2+"&currentId="+currentId+"&forceFlag="+forceFlag+"&timeStamp="+new Date().getTime(); xmlHttp.open("GET",url,true); if(forceFlag=="true"){ xmlHttp.onreadystatechange=sameNameAlertForce; }else{ xmlHttp.onreadystatechange=sameNameAlert; } xmlHttp.send(null); } //} } /** * 校验对象objectName的属性attribName在数据库中是否存在重名,currentId用于编辑查询时排除对象自身* objectName 对象名* attribName 属性名* forceFlag 强制检测标识,如果为true,重名不能提交,否则仅提醒重名*/function checkSameName(objectName,attribName,forceFlag){ // 只有在新增时校验重名//if(document.all["actionType"].value=="add"){ //创建xmlHttpRequest对象createXMLHttpRequest(); var attribValue=document.all["bean."+attribName].value; var currentId=document.all["bean.id"].value; //只有属性值长度大于零时进行校验重名if(attribValue.length>0){ //请求地址var url="eplugger.checkSameName?objectName="+objectName+"&attribName="+attribName+ "&attribValue="+attribValue+"&currentId="+currentId+"&forceFlag="+forceFlag+"&timeStamp="+new Date().getTime(); xmlHttp.open("GET",url,true); if(forceFlag=="true"){ xmlHttp.onreadystatechange=sameNameAlertForce; }else{ xmlHttp.onreadystatechange=sameNameAlert; } xmlHttp.send(null); } //} } /** * 存在同名时d出提示信息*/function sameNameAlert(){ if(xmlHttp.readyState==4){ if(xmlHttp.status==200){ var mes=xmlHttp.responseXML; var targetValue=mes.getElementsByTagName("checkResult")[0].firstChild.nodeValue; //如果存在重名,d出提示信息if(targetValue=="true"){ alert(mes.getElementsByTagName("alertInfo")[0].firstChild.nodeValue); if(document.all["existSameRecord"]!=null){ document.all["existSameRecord"].value="true"; } }else{ if(document.all["existSameRecord"]!=null){ document.all["existSameRecord"].value="false"; } } } } } /** * 存在同名时d出提示信息,同时不允许提交*/function sameNameAlertForce(){ if(xmlHttp.readyState==4){ if(xmlHttp.status==200){ var mes=xmlHttp.responseXML; var targetValue=mes.getElementsByTagName("checkResult")[0].firstChild.nodeValue; //如果存在重名,d出提示信息,并在页面标记重名状态if(targetValue=="true"){ alert(mes.getElementsByTagName("alertInfo")[0].firstChild.nodeValue); //在页面标记重名状态,用于判断是否允许提交if(document.all["existSameRecord"]!=null){ document.all["existSameRecord"].value="true"; } } //如果不存在重名,清楚页面重名状态的内容else{ if(document.all["existSameRecord"]!=null){ document.all["existSameRecord"].value="false"; } } } } } function WaitObj(ac,ti,ca){ var action=ac; var title=ti==‘‘?‘提交‘:ti; var isCancel=ca; } /**将oFrm中的独立单选按钮自动选择 */ function automaticChooseSingleRadio(oFrm){ for (i = 0; i < oFrm.elements.length; i++) { type = oFrm.elements[i].type; if ((type == "radio") && isNaN(document.all[oFrm.elements[i].name].length)) { oFrm.elements[i].checked="true"; } } } /**显示更多查询 **/ function moreSearch(){ var moreSearchDisplay=false; if(document.all["queryBean.defaultSearchFlag"].value=="1"){ moreSearchDisplay=true; } if(moreSearchDisplay){ document.all[‘more‘].style.display=‘block‘; document.all["queryBean.defaultSearchFlag"].value="0"; }else{ document.all[‘more‘].style.display=‘none‘; document.all["queryBean.defaultSearchFlag"].value="1"; } }

//控制左侧框架的宽度 function changeframe(direction){ if(direction=="left"){ table.style.display="none"; toLeft.style.display="none"; toRight.style.display=""; top.window.frames["leftFrame"].scrollTo(0, 0); top.window.frames["leftFrame"].document.body.scroll="no"; top.content.cols="25,*"; } if(direction=="right"){ table.style.display=""; toLeft.style.display=""; toRight.style.display="none"; top.window.frames["leftFrame"].document.body.scroll="auto"; top.content.cols="146,*"; } } //根据左侧框架的宽度,决定显示的内容 function adjustContent(){ if(top.content.cols=="25,*"){ top.window.frames["leftFrame"].document.body.scroll="no"; table.style.display="none"; toLeft.style.display="none"; toRight.style.display=""; } } //************************************** DWR 实现自动完成 开始 ××××××××××××××××××××××××××××××××××××××××

//初始化需要自动完成的文本框信息var autoComplete = null; function initAjaxText(textName){ var configuration = { instanceName: "autoComplete", textbox: document.getElementById(textName) }; autoComplete = new neverModules.modules.autocomplete(configuration); autoComplete.useContent = true; autoComplete.useSpaceMatch = true; autoComplete.ignoreWhere = true; autoComplete.create(); } /* 显示autoComplete */ function showAutocomplete(evt) { autoComplete.hdleEvent(evt); window.setTimeout(function () { autoComplete.closeAnimateImage(); },1000); } /** * textName 文本区属性名* textId 文本区字段对应的编号字段名* isNeedUnit 如果值为"true",则检索时判断是否加单位条件,(可选)* actiontType 提交动作*/ //根据用户输入生成信息提示var userInput=""; //文本框对应的编号属性,eg bean.chargerCode var idTextName=""; //文本框的属性名称,eg bean.chargerName var displayTextName=""; function generatorSuggestContent(textName,textId,isNeedUnit){ //初始化自动生成if(autoComplete==null){ initAjaxText(textName); idTextName=textId; displayTextName=textName; } //关闭原因 不兼容 IE7和firefox //if (window.event!=null && autoComplete.isValidKey(window.event)==false ) {// showAutocomplete(window.event); // return; // } var thisData; thisData={personName:document.all[textName].value}; if(isNeedUnit){ thisData.isNeedUnit = isNeedUnit; } //控制中文录入过程中,不查询if(document.all[textName].value!=‘‘){ if(userInput==document.all[textName].value){ PersonBO.searchPerson(thisData,pageLoadHdle); }else{ //输入信息改变时,将编号对应的名称置为空document.all[textId].value=""; PersonBO.searchPerson(thisData,pageLoadHdle); userInput=document.all[textName].value; } } } function pageLoadHdle(data) { autoComplete.setDataSource(data); autoComplete.callback = function (autocompleteValue, autocompleteContent) { //autocompleteValue值结构为“职工号:asdf PersonBO.getPersonByAccount(autocompleteContent.split(":")[1],getIdByAccount); document.all[displayTextName].value=autocompleteValue; } autoComplete.create(); autoComplete.expandAllItem(); autoComplete.showAnimateImage("../widgets/suggest/images/indicator.gif"); window.setTimeout( function closeAnimateImageAfter1seconds() { autoComplete.closeAnimateImage(); }, 1000); } //通过人员职工号得到人员编号、部门编号、教研室编号 function getIdByAccount(data){ //autoComplete.callback = function (autocompleteValue, autocompleteContent) { for(i=0;i<data.length;i++){ document.all[idTextName].value = data[i].content.split(":")[0]; //if(data[i].content==autocompleteContent){ //部门if(document.all["author.authorUnitId"]!=null){ document.all["author.authorUnitId"].value=data[i].content.split(":")[1]; } if(document.all["bean.unitId"]!=null){ document.all["bean.unitId"].value=data[i].content.split(":")[1]; changeUnitIdDisabledStatus(); } if(document.all["bean.divisionId"]!=null){ document.all["bean.divisionId"].value=data[i].content.split(":")[2]; } //教研室if(document.all["author.authorDivisionId"]!=null){ document.all["author.authorDivisionId"].value=data[i].content.split(":")[2]; } if(document.all["bean.authorDivisionId"]!=null){ document.all["bean.authorDivisionId"].value=data[i].content.split(":")[2]; } //人员编号if(document.all["author.authorId"]!=null){ document.all["author.authorId"].value=data[i].content.split(":")[0]; } if(document.all["bean.authorId"]!=null){ document.all["bean.authorId"].value=data[i].content.split(":")[0]; } //性别if(document.all["author.sexId"]!=null){ document.all["author.sexId"].value=data[i].content.split(":")[3]; } if(document.all["bean.sexId"]!=null){ document.all["bean.sexId"].value=data[i].content.split(":")[3]; } if(document.all["bean.chargerGender"]!=null){ document.all["bean.chargerGender"].value=data[i].content.split(":")[3]; } //职称if(document.all["author.titleId"]!=null){ document.all["author.titleId"].value=data[i].content.split(":")[4]; } if(document.all["bean.titleId"]!=null){ document.all["bean.titleId"].value=data[i].content.split(":")[4]; } if(document.all["bean.applierTitleId"]!=null){ document.all["bean.applierTitleId"].value=data[i].content.split(":")[4]; } if(document.all["bean.chargerTitleId"]!=null){ document.all["bean.chargerTitleId"].value=data[i].content.split(":")[4]; } //学历if(document.all["author.eduLevelId"]!=null){ document.all["author.eduLevelId"].value=data[i].content.split(":")[5]; } if(document.all["bean.apllierEduLevelId"]!=null){ document.all["bean.apllierEduLevelId"].value=data[i].content.split(":")[5]; } if(document.all["bean.eduLevelId"]!=null){ document.all["bean.eduLevelId"].value=data[i].content.split(":")[5]; } //学位if(document.all["author.eduDegreeId"]!=null){ document.all["author.eduDegreeId"].value=data[i].content.split(":")[6]; } //学位if(document.all["bean.eduDegreeId"]!=null){ document.all["bean.eduDegreeId"].value=data[i].content.split(":")[6]; } //出生日期if(document.all["bean.birthday"]!=null){ document.all["bean.birthday"].value=data[i].content.split(":")[7]; } if(document.all["bean.chargerBrithday"]!=null){ document.all["bean.chargerBrithday"].value=data[i].content.split(":")[7]; } //行政职务if(document.all["bean.duty"]!=null){ document.all["bean.duty"].value=data[i].content.split(":")[8]; } //学术兼职if(document.all["bean.learningBywork"]!=null){ document.all["bean.learningBywork"].value=data[i].content.split(":")[9]; } if(document.all["bean.workUnit"]!=null){ document.all["bean.workUnit"].value=data[i].content.split(":")[1]; } if(document.all["bean.tel"]!=null){ document.all["bean.tel"].value=data[i].content.split(":")[10]; } //} } //} } /**改变单位的Disabled的状态*/function changeUnitIdDisabledStatus(){ if(document.all["bean.unitId"].value!=""){// if(document.all["bean.divisionId"]!=null){// generateOption("project.unitId","project.divisionId");// } document.all["bean.unitId"].disabled=true; }else{ document.all["bean.unitId"].disabled=false; } }//—————————————————————————————————————————————————— DWR 实现自动完成 结束 ———————————————————

/*****************************************************以下 *** 作,完成审核功能**************************************/

//多条审核新增页面 function checkListAdd(moduleName,pageForm){ if(isSelected()){ var moduleIds=getModuleIds(); window.location="../check/check.do?actionType=checkListAdd&moduleIds="+moduleIds+"&moduleName="+moduleName+"&pageFrom="+pageForm; }else{ alert("请选择需要审核的记录");return; } } //将所选择的moduleIds组成以逗号隔开的字符串 function getModuleIds(){ var fromSelect = document.getElementsByName("selected"); var moduleIds=""; for (var i = 0; i <fromSelect.length; i++) { if (fromSelect[i].checked == true) { moduleIds+=fromSelect[i].value+","; } if(i==fromSelect.length-1){ moduleIds=moduleIds.substring(0,moduleIds.length-1); } } return moduleIds; }/*****************************************************以上 *** 作,完成审核功能功能**************************************/ /****************************************************以下 *** 作,完成点击列表标题排序功能*******************************/ /**针对特定列信息进行排序columnName 排序的列名orderType 排序方式:升序或降序 */ var columnName,orderType,modelName; function orderContent(objectName,param1,param2){ columnName=param1; orderType=param2; modelName=objectName; var result=PageListTag.getOutputTableForDWR(modelName,"commonList",true,true,true,columnName,orderType,refreshTableContent); } function refreshTableContent(result){ var tableContent="<table cellSpacing=‘0‘ cellPadding=‘0‘ id=‘table‘ align=‘center‘ border=‘0‘>"; tableContent+=result; tableContent+="</table>"; document.getElementById("listContent").innerHTML=tableContent; var tdObj=document.getElementById("title_"+columnName); }/*****************************************************以上 *** 作,完成点击列表标题排序功能*******************************/ //得到当前应用的地址function getWebAppAddress(){ var address=window.document.location.protocol+"//"+window.document.location.host; var pathname=window.document.location.pathname.substr(1); pathname=pathname.substr(0,pathname.indexOf("/")); address+="/"+pathname; return address;}

/*****************************************************保存成功后的d出层效果**************************************/ var docEle = function() { return document.getElementById(arguments[0]) || false;}//moduleId:所属模块person//optionType: *** 作方式add,editfunction openNewDiv(moduleId,optionType) { var optionName="编辑"; if(moduleId == "contract"){//横向与枞向共用一个Action请求moduleId = "project"; } var addOrEditLink=moduleId+".do?actionType=edit"; if("add"==optionType){ optionName="新增";addOrEditLink=moduleId+".do?actionType=add"; } var m = "mask"; if (docEle("remindDiv")) document.body.removeChild(docEle("remindDiv")); if (docEle(m)) document.body.removeChild(docEle(m)); //新d出层var newDiv = document.getElementById("PopupDiv"); DivRefWidth = 401; DivRefHeight = 203; newDiv.style.width = DivRefWidth + "px"; newDiv.style.height = DivRefHeight + "px"; newDiv.style.top = (document.body.scrollTop + document.body.clientHeight/2 - DivRefHeight/2) + "px"; newDiv.style.left = (document.body.scrollLeft + document.body.clientWidth/2 - DivRefWidth/2) + "px"; newDiv.style.display = "block"; newDiv.style.zIndex = "60"; newDiv.style.backgroundImage="url(‘../../css/css_default/img/save.jpg‘)"; var divHead = "<div class=‘top‘>提示信息</div>"+ "<div style=‘float:right;margin-right:5px;cursor:hand‘ onclick=‘DivSetVisible(false)‘ align=‘right‘><img src=‘../../css/css_default/img/x.gif‘ border=‘0‘></div>"+ "<br><div class=‘text‘>信息 *** 作成功!</div><br><div class=‘text_1‘>请选择下一步 *** 作:<br><br>"; var divBody = ""; if(arguments.length > 2){ var link_action = arguments[2].split("&&"); var link_content = arguments[3].split("&&"); if(link_action.length < 4){ for(var i = 0; i < link_action.length ;i++){ divBody += "[<a href=‘"+link_action[i]+"‘ class=‘list_link‘>"+link_content[i]+"</a>]<br>"; } }else{ //大于4行时, 两个排一行for(var i = 0; i < link_action.length ;i++){ divBody += "[<a href=‘"+link_action[i]+"‘ class=‘list_link‘>"+link_content[i]+"</a>]&nbsp;&nbsp;"; if(i % 2 == 0){ divBody += "<br>"; } } } }else{//通用 Div层提示 divBody = "[<a href=‘"+addOrEditLink+"‘ class=‘list_link‘>继续"+optionName+"</a>]<br>"+ "<br>[<a href=‘"+moduleId+".do?actionType=list‘ class=‘list_link‘>返回列表</a>]" ; } var divFoot ="</div>"; newDiv.innerHTML = divHead+divBody+divFoot; //mask遮罩层var newMask = document.createElement("div"); newMask.id = "maskLayer"; newMask.style.position = "absolute"; newMask.style.zIndex = "50"; _scrollWidth = Math.max(document.body.scrollWidth,document.documentElement.scrollWidth); _scrollHeight = Math.max(document.body.scrollHeight,document.documentElement.scrollHeight); newMask.style.width = _scrollWidth + "px"; newMask.style.height = _scrollHeight + "px"; newMask.style.top = "0px"; newMask.style.left = "0px"; newMask.style.background = "ebebeb"; newMask.style.filter = "alpha(opacity=40)"; newMask.style.opacity = "0.40"; newMask.style.display="block";

//创建iframe对象,作为div层遮盖界面select元素var ifrRef = document.getElementById("DivShim"); ifrRef.style.width = newDiv.offsetWidth; ifrRef.style.height = newDiv.offsetHeight; ifrRef.style.top = newDiv.style.top; ifrRef.style.left = newDiv.style.left; ifrRef.style.zIndex = newDiv.style.zIndex -1; ifrRef.style.display = "block";

document.body.appendChild(newMask); //设置界面select元素不可编辑 var allElement = document.all; for(var i=0;i<allElement.length;i++){ if(allElement[i].tagName=="SELECT"){ allElement[i].disabled=true; } }}

//设置提示信息窗口的隐藏function DivSetVisible(state){ var DivRef = document.getElementById(‘PopupDiv‘); var IfrRef = document.getElementById(‘DivShim‘); var maskLayer = document.getElementById(‘maskLayer‘); DivRef.style.display = "none"; IfrRef.style.display = "none"; maskLayer.style.display = "none"; var allElement = document.all; //恢复界面select元素可编辑 for(var i=0;i<allElement.length;i++){ if(allElement[i].tagName=="SELECT"){ allElement[i].disabled=false; } }}

//当select需要常量参数,而没有得到时,给用户提示信息function beforeSelectPrompt(name){ var obj = document.getElementsByName("bean."+name)[0]; if(obj == null){ obj = document.getElementsByName("@"+name)[0]; } if(obj.selectedIndex < 1){ var tt = obj.parentNode.parentNode.previousSibling.innerHTML; if(undefined==tt){ var title = ""; }else{ var title = tt.replaceAll(":",""); }if(obj.disabled==false){ alert(‘请先选择:‘+title); obj.focus(); } }}

/** * @param object elem : the DOM element to be used * @param string attr : the attribute to get * @return boolean : the value of the attribute or null on error */function elemGetAttribute(elem,attr) { try { return eval("elem."+attr); } catch (e) { return null; }}/** * 创建选择数据d出层 */function createDataScopeDIV(act){ if(parseInt(act)>1){ var div= document.createElement("div"); div.id = "allselect"; div.innerHTML = "<div class=‘allselect‘>已选中本页数据&nbsp;<a onClick=MM_showHideLayers(‘allselect‘,‘‘,‘hide‘,‘1‘) style=‘cursor:hand;‘>点击选中所有页面数据</a></div>"; document.body.appendChild(div); }}

/** *************************** 引入jquery autoComplete 张巧飞 20100924 *******************************************///人员信息var personAutoComplete;//从库中读取人员数据信息function getPersonAutoCompleteInfo(unitScope){ $.getJSON("../person/person.do?actionType=autoComplete&userManageScope="+unitScope+"&date="+new Date(),initPersonInfo);}

//清除自动完成组件function cleanPersonAutoComplete(attribName){ $("input[name=‘"+attribName+"‘]").unautocomplete(); $("input[name=‘"+attribName+"‘]").unbind();}//绑定自动完成组件function bindPersonAutoComplete(attribName){ $("input[name=‘"+attribName+"‘]").autocomplete(personAutoComplete, { mustMatch:true, selectFirst:true, scroll:true, minChars: 0, cacheLength:1, max:40, width: 400, scrollHeight: 250, matchContains: "word", autoFill: false, formatItem: function(row, i, max) { return i + "/" + max + ": \"" + row.name + "\" " + " ["+row.unitName+"] "+ row.spell+" 职工号:"+row.account; }, formatMatch: function(row, i, max) { return row.spell + " " + row.name+" "+row.unitName; }, formatResult: function(row) { return row.name.substr(1,row.name.length); } }); $("input[name=‘"+attribName+"‘]").result(cascadeChangePersonInfo); }

/** *************************** 引入jquery autoComplete 结束 ************************ssssssssss*******************/

/** *************************** 引入jquery 动态验证某属性在系统中是否重复出现 张金辉 20110322 *******************************************/ /**例如:检验名称为“test”的项目是否存在,其中columnNames为回显列表的列名,用逗号隔开。 参数传递如下:objectName :project;limitProperty:name;remindContent:项目名称的项目已经存在,如下所示:columnNames:name,code,chargerName,unitId**/function checkPropertyValueSame(objectName,limitProperty,remindContent,columnNames){ //初始化参数 var id=document.all["bean.id"].value; var limitPropertyValue=$("#"+limitProperty).val(); var url=document.forms[0].action+"?actionType=checkPropertyValueSame&id="+id+"&objectName="+objectName+"&limitProperty="+limitProperty+"&limitPropertyValue="+limitPropertyValue+"&columnNames="+columnNames; //调用服务器端程序 $.get(url,function(data){ if(data!=""){ //showPrompt(‘#authorizeSn‘, ‘相同项目批准号已经存在,如下所示:‘,data,false,false,"callbackFunction",0,0,600,200); showPrompt("#"+limitProperty, remindContent,data,"callbackFunction"); }else{ $.popup._autoClose(); } });}/** *************************** 引入jquery 动态验证某属性在系统中是否重复出现 张金辉 20110322 *******************************************//** * * 实现Enter键自动将焦点切换到表单下一个控件对象上 */function addEnterEvent(){ $("form").keyup(function() { //判断回车符号if(event.keyCode==13){ var srcElementName=event.srcElement.name; //获取当前对象在表单中的位置var currentIndex=$("form :input:visible").index(event.srcElement); if(currentIndex<$("form :input:visible").size()-1){ while($("form :input:visible").get(currentIndex).name==$("form :input:visible").get(currentIndex+1).name){ currentIndex=currentIndex+1; } while($("form :input:visible").get(currentIndex+1).type=="hidden"){ currentIndex=currentIndex+1; } $("form :input:visible").get(currentIndex+1).focus(); } } });}

/** *************************** 精确计算 鲁璇 20120229 *******************************************///JS 精确计算 乘法 function FloatMul(arg1,arg2){ var m=0,s1=arg1.toString(),s2=arg2.toString(); try{m+=s1.split(".")[1].length}catch(e){} try{m+=s2.split(".")[1].length}catch(e){} return Number(s1.replace(".",""))*Number(s2.replace(".",""))/Math.pow(10,m); } //JS 精确计算 除法 function FloatDiv(arg1,arg2){ var t1=0,t2=0,r1,r2; try{t1=arg1.toString().split(".")[1].length}catch(e){} try{t2=arg2.toString().split(".")[1].length}catch(e){} with(Math){ r1=Number(arg1.toString().replace(".","")); r2=Number(arg2.toString().replace(".","")); return (r1/r2)*pow(10,t2-t1); } } //JS 精确计算 加法 function FloatAdd(arg1,arg2){ var r1,r2,m; try{r1=arg1.toString().split(".")[1].length}catch(e){r1=0} try{r2=arg2.toString().split(".")[1].length}catch(e){r2=0} m=Math.pow(10,Math.max(r1,r2)); return (arg1*m+arg2*m)/m; } //JS 精确计算 减法 function FloatSub(arg1,arg2){ var r1,r2,m,n; try{r1=arg1.toString().split(".")[1].length}catch(e){r1=0} try{r2=arg2.toString().split(".")[1].length}catch(e){r2=0} m=Math.pow(10,Math.max(r1,r2)); //动态控制精度长度 n=(r1>=r2)?r1:r2; return ((arg1*m-arg2*m)/m).toFixed(n); } //四舍五入 function JSRound(fNum,fBit){ var i = 1; var m = 1; var tempNum = fNum; for(i=1;i <= fBit;i++) m = m * 10; tempNum = tempNum * m; tempNum = Math.round(tempNum); tempNum = tempNum / m; return tempNum; } //日期和年度查询切换function yearDateChange(attribName,dateType){ var attribName1 = attribName.replace(‘.‘,‘\.‘); $("#"+attribName1+"_"+dateType).css("display",""); //显示年度隐藏日期if(dateType=="Select"){ $("#"+attribName1+"_Input").css("display","none"); //因为select和input的name相同的话,后台接收有问题,因此在这里处理$("input[name=‘@"+attribName+"&>=‘]").attr("disabled",true); $("input[name=‘@"+attribName+"&<=‘]").attr("disabled",true); $("select[name=‘@"+attribName+"&>=‘]").attr("disabled",false); $("select[name=‘@"+attribName+"&<=‘]").attr("disabled",false); //如果不是年度范围查询,在切换查询时还原为初始的代码$("select[name=‘@"+attribName+"‘]").attr("name","@"+attribName+"&>="); $("input[name=‘dateScope_@"+attribName+"‘]").attr(‘checked‘,true); $("select[name=‘@"+attribName+"&<=‘]").attr(‘disabled‘,false); } //显示日期隐藏年度if(dateType=="Input"){ $("#"+attribName1+"_Select").css("display","none"); //因为select和input的name相同的话,后台接收有问题,因此在这里处理$("select[name=‘@"+attribName+"&>=‘]").attr("disabled",true); $("select[name=‘@"+attribName+"&<=‘]").attr("disabled",true); $("input[name=‘@"+attribName+"&>=‘]").attr("disabled",false); $("input[name=‘@"+attribName+"&<=‘]").attr("disabled",false); } //清空历史数据$("select[name=‘@"+attribName+"&>=‘]").val(""); $("select[name=‘@"+attribName+"&<=‘]").val(""); $("input[name=‘@"+attribName+"&>=‘]").val(""); $("input[name=‘@"+attribName+"&<=‘]").val(""); } //年度查询和年度范围查询切换function changeDateDisplay(target,attribName){ //如果选中时间范围,两个时间条件均有效。否则仅第一个时间条件有效且其查询条件变为等于某一时间 var attr1 = $("select[name=‘"+attribName+"&>=‘]"); var attr2 = $("select[name=‘"+attribName+"&<=‘]"); if(target.checked){ if(attr2!=undefined) attr2.attr("disabled",false); $("select[name=‘"+attribName+"‘]").attr("name",attribName+"&>="); }else{ if(attr2!=undefined){ attr2.val(""); attr2.attr("disabled",true); } if(attr1!=undefined) attr1.attr("name",attribName); } }

盈创动力之 JS校验方法,码迷,mamicode.com

盈创动力之 JS校验方法

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/1006964.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-22
下一篇 2022-05-22

发表评论

登录后才能评论

评论列表(0条)

保存