//=============================================
//建立日期:2004年3月25日
//功能概述:通用函数集,供系统全局调用
//调用方法:在调用文件头引入即可,如下:
//
//
//
//=============================================
//==========================================
//功能: 去掉字符左边的空格
//输入参数:要格式化的字符串
//返回值:去掉左边空格的字符串
//调用方法
//==========================================
function ltrim(str)
{
if (str==null) return null;
var s="";
for (var i=0;i=0;i--)
{
if (str.charAt(i)!=" ")
{
s=str.substring(0,i+1);
break;
}
}
return s;
}
//==========================================
//功能: 去掉字符左右边的空格
//输入参数:要格式化的字符串
//返回值:去掉左右边空格的字符串
//调用方法
//==========================================
function trim(str)
{
return(ltrim(rtrim(str)));
}
//==========================================
//功能: 字符转为大写
//输入参数:无
//返回值:空
//调用方法:在文本控件里onkeydown="jsUpperCase();"
//==========================================
function jsUpperCase()
{
if ((window.event.keyCode>=97) && (window.event.keyCode<=122))
window.event.keyCode = window.event.keyCode-32;
}
//==========================================
//功能: 把输入的字符转为大写
//输入参数:当前对象
//返回值:空
//调用方法:在文本控件里onblur="toUpperCase(this);"
//==========================================
function toJsUpperCase(obj)
{
try {
var s = obj.value;
if (trim(s) == "") return;
obj.value = s.toUpperCase();
} catch(e) {
}
}
//==========================================
//功能: 把输入的字符转为小写
//输入参数:无
//返回值:空
//调用方法:在文本控件里onkeydown="jsLowerCase();"
//==========================================
function jsLowerCase()
{
if ((window.event.keyCode>=65) && (window.event.keyCode<=90))
window.event.keyCode = window.event.keyCode+32;
}
//==========================================
//功能: 把输入的字符转为小写
//输入参数:当前对象
//返回值:空
//调用方法:在文本控件里onblur="toJsLowerCase(this);"
//==========================================
function toJsLowerCase(obj)
{
var s = obj.value;
if (trim(s) == "") return;
obj.value = s.toLowerCase();
}
//==========================================
//功能: 只能输入数字
//输入参数:
//obj:输入域对象
//symbol:输入符号,有"-","."两种,用","分开
//bite:小数点后面位数,默认2位
//返回值:空
//调用方法:在文本控件里onkeypress="typeNumber(this,'.,-',2);"
//==========================================
function typeNumber(obj,symbol,bite)
{
var str = trim(obj.value);
var bDot = false;
var bNega = false;
if (typeof(symbol) == 'undefined') symbol = "";
if (typeof(bite) == 'undefined') bite = 2;
bDot = (symbol.indexOf(".")>=0?true:false);
bNega = (symbol.indexOf("-")>=0?true:false);
if (bNega) //允许输入负号
{
//只能第一位为负号
if (str.length>0 && window.event.keyCode == 45)
{
window.event.returnValue = false;
return;
}
//只能输入一个负号
if (str.indexOf("-")>=0 && window.event.keyCode == 45)
{
window.event.returnValue = false;
return;
}
}
if (bDot) //允许输入小数点
{
//只能输入一个小数点
if (str.indexOf(".")>=0 && window.event.keyCode == 46)
{
window.event.returnValue = false;
return;
}
}
//验证小数点后两位
if ( str.indexOf(".")>=0 ) {
var temp = str;
if ( str.indexOf("-")>=0 ) {
temp = str.substring(1,str.length);
}
if ( ! behindDot(temp,bite -1) ) {
window.event.returnValue = false;
return;
}
}
if (window.event.keyCode<48 || window.event.keyCode>57)
{
if ((bDot && window.event.keyCode == 46) || (bNega && window.event.keyCode == 45))
{
return;
}
window.event.returnValue = false;
}
}
//==========================================
//功能: 只能输入整数
//输入参数:negative 是否允许输入负数,true:允许输入负数,false:不允许,默认:false
//返回值:空
//调用方法:在文本控件里onkeypress="typeInteger(this,false);"
//==========================================
function typeInteger(obj,negative)
{
if (typeof(negative) == 'undefined') negative = false;
typeNumber(obj,(negative==true?"-":""));
}
//==========================================
//功能: 只能输入浮点数
//参数:
//obj,输入域对象
//negative:是否允许输入负数,true:允许输入负数,false:不允许,默认:false
//返回值:空
//调用方法:在文本控件里onkeypress="typeFloat(this,false);"
//==========================================
function typeFloat(obj,negative)
{
if (typeof(negative) == 'undefined') negative = false;
typeNumber(obj,(negative==true?"-,.":"."));
}
//==========================================
//功能: 只能输入整数
//参数:当前对象
//返回值:boolean
//调用方法:在文本控件里onblur="verifyInteger(this);"
//==========================================
function verifyInteger(obj,negative)
{
if (typeof(negative) == 'undefined') negative = false;
verifyNumber(obj,(negative==true?"-":""));
}
//==========================================
//功能: 只能输入浮点数
//参数:当前对象
//返回值:boolean
//调用方法:在文本控件里onblur="verifyFloat(this);"
//==========================================
function verifyFloat(obj,negative)
{
if (typeof(negative) == 'undefined') negative = false;
verifyNumber(obj,(negative==true?"-,.":"."));
}
//==========================================
//功能: 只能输入有效数字
//参数:
//obj:输入域对象
//symbol:输入符号,有"-","."两种,用","分开
//bite:小数点后位数
//返回值:boolean
//调用方法:在文本控件里onblur="verifyNumber(this,'-,.',2);"
//==========================================
function verifyNumber(obj,symbol,bite)
{
var bDot = false;
var bNega = false;
if (typeof(symbol) == 'undefined') symbol = "";
if (typeof(bite) == 'undefined') bite = 2;
bDot = (symbol.indexOf(".")>=0?true:false);
bNega = (symbol.indexOf("-")>=0?true:false);
var errInfo = "不是有效的数字!\n\n请重新输入!";
var str = trim(obj.value);
if (str == "") return true;
try
{
if (!isNumber(str,symbol))
{
alert("\"" + str + "\""+errInfo);
obj.value="";
obj.focus();
return false;
}
}
catch (e)
{
alert("\"" + str + "\""+errInfo);
obj.value="";
obj.focus();
return false;
}
//验证小数点后两位
if ( str.indexOf(".")>=0 ) {
var temp = str;
if ( str.indexOf("-")>=0 ) {
temp = str.substring(1,str.length);
}
if( !behindDot(temp,bite) ) {
alert("\"" + str + "\"小数位不能多于"+ bite+"位!" )
return false;
}
}
return true;
}
//==========================================
//功能: 只能输入有效数字(金额)
//参数:
//obj:输入域对象
//symbol:输入符号,有"-","."两种,用","分开
//bite:小数点后位数
//返回值:boolean
//调用方法:在文本控件里onblur="verifyMoney(this,'-,.',2);"
//==========================================
function verifyMoney(obj,symbol,bite)
{
if (typeof(symbol) == 'undefined') symbol = "";
if (typeof(bite) == 'undefined') bite = 2;
var errInfo = "不是有效金额,请重新输入!";
var str = trim(obj.value);
if (str == "") return true;
try
{
if (!isNumber(str,symbol))
{
alert(errInfo);
obj.value="";
obj.focus();
return false;
}
if ((str).match(/^((\d{1,3}(,\d{3})*(.((\d{3},)*\d{1,3}))?)|(\d+(.\d+)?))$/) == null) {
alert(errInfo);
obj.value="";
obj.focus();
return false;
}
}
catch (e)
{
alert("\"" + str + "\""+errInfo);
obj.value="";
obj.focus();
return false;
}
//验证小数点后两位
if ( str.indexOf(".")>=0 ) {
var temp = str;
if ( str.indexOf("-")>=0 ) {
temp = str.substring(1,str.length);
}
if( !behindDot(temp,bite) ) {
alert("\"" + str + "\"小数位不能多于"+ bite+"位!" )
return false;
}
}
return true;
}
//==========================================
//功能: 验证是否为有效数字,允许用科学计数法,即包含字母E
//str:传入的字符串
//symbol:输入符号,有"-","."两种,用","分开
//返回值:boolean
//调用方法:"
//==========================================
function isNumber(str,symbol)
{
var bDot = false;
var bNega = false;
if (typeof(symbol) == 'undefined') symbol = "";
bDot = (symbol.indexOf(".")>=0?true:false);
bNega = (symbol.indexOf("-")>=0?true:false);
var bFlag = true;
for(var i=0;i57)
{
if (bDot && str.charCodeAt(i)==46) continue;
if (bNega && str.charCodeAt(i)==45) continue;
if (str.charCodeAt(i) == 69) continue; //字母 E,科学计数表示法
bFlag = false;
break;
}
}
return bFlag;
}
//======================================
//验证小数点后面的位数是否超过指定长度
//str:数字字符串
//length:小数位最大值
//======================================
function behindDot(str,length) {
var re = new RegExp("^[0-9]+(.[0-9]{0,"+ length +"})?$");
return re.test(str);
}
//==========================================
//Purpose:把字符串转化为整数
//参数:s--要转化为整数的字符串
//返回值:转化后的整数
//说明:JavaScript自带的函数对于处理数字字符串前带0或为0的有误,
//如使用parseInt("0025")返回的并不是25,而是21,又如parseInt("0")返回并不是0,而是NaN
//下面的自定义函数可以处理这一Bug
//调用方法:
//==========================================
function parseMyInt(s)
{
var str = trim(s)
if (str == "") return 0;
try
{
for (var i=0;i1?"true":"false";
arr.multiRows = multiRows;
var sFeature="dialogWidth:"+width+"px;dialogHeight:"+height+"px;Status:0;resizable:1;help:0";
//paramNameList 参数列表,格式:paramName1=paramControlName1,paramName2=paramControlName2,...
if (paramNameList != "")
{
var paramArr = paramNameList.split(",");
var paramControlName,paramStr,paramList;
paramList = "";
for(var m=0;m1)
{
for(var i=0;icolCount-1) return "";
for(var i=0;i maxlength){
slt.value = mContext.substr(0, maxlength);
}
return true;
}
function checkMoney(money){
var reg = /(^\d+$)|(^\d+.\d+$)/g;
if(reg.test(money)){
return true;
}else{
return false;
}
}
function toAmountUpper(currencyDigits) {
//Constants:
var MAXIMUM_NUMBER = 99999999999.99;
// Predefine the radix characters and currency symbols for output:
var CN_ZERO = "零";
var CN_ONE = "壹";
var CN_TWO = "贰";
var CN_THREE = "叁";
var CN_FOUR = "肆";
var CN_FIVE = "伍";
var CN_SIX = "陆";
var CN_SEVEN = "柒";
var CN_EIGHT = "捌";
var CN_NINE = "玖";
var CN_TEN = "拾";
var CN_HUNDRED = "佰";
var CN_THOUSAND = "仟";
var CN_TEN_THOUSAND = "万";
var CN_HUNDRED_MILLION = "亿";
var CN_SYMBOL = "";
var CN_DOLLAR = "元";
var CN_TEN_CENT = "角";
var CN_CENT = "分";
var CN_INTEGER = "整";
// Variables:
var integral; // Represent integral part of digit number.
var decimal; // Represent decimal part of digit number.
var outputCharacters; // The output result.
var parts;
var digits, radices, bigRadices, decimals;
var zeroCount;
var i, p, d;
var quotient, modulus;
// Validate input string:
currencyDigits = currencyDigits.toString();
if (currencyDigits == "") {
return "";
}
if (currencyDigits.match(/[^,.\d]/) != null) {
alert("Invalid characters in the input string!");
return "";
}
if ((currencyDigits).match(/^((\d{1,3}(,\d{3})*(.((\d{3},)*\d{1,3}))?)|(\d+(.\d+)?))$/) == null) {
alert("Illegal format of digit number!");
return "";
}
//Normalize the format of input digits:
currencyDigits = currencyDigits.replace(/,/g, ""); // Remove comma delimiters.
currencyDigits = currencyDigits.replace(/^0+/, ""); // Trim zeros at the beginning.
// Assert the number is not greater than the maximum number.
if (Number(currencyDigits) > MAXIMUM_NUMBER) {
alert("金额长度太长,请检查后重试。");
return "";
}
//Process the coversion from currency digits to characters:
//Separate integral and decimal parts before processing coversion:
parts = currencyDigits.split(".");
if (parts.length > 1) {
integral = parts[0];
decimal = parts[1];
// Cut down redundant decimal digits that are after the second.
decimal = decimal.substr(0, 2);
}
else {
integral = parts[0];
decimal = "";
}
// Prepare the characters corresponding to the digits:
digits = new Array(CN_ZERO, CN_ONE, CN_TWO, CN_THREE, CN_FOUR, CN_FIVE, CN_SIX, CN_SEVEN, CN_EIGHT, CN_NINE);
radices = new Array("", CN_TEN, CN_HUNDRED, CN_THOUSAND);
bigRadices = new Array("", CN_TEN_THOUSAND, CN_HUNDRED_MILLION);
decimals = new Array(CN_TEN_CENT, CN_CENT);
// Start processing:
outputCharacters = "";
// Process integral part if it is larger than 0:
if (Number(integral) > 0) {
zeroCount = 0;
for (i = 0; i < integral.length; i++) {
p = integral.length - i - 1;
d = integral.substr(i, 1);
quotient = p / 4;
modulus = p % 4;
if (d == "0") {
zeroCount++;
}
else {
if (zeroCount > 0)
{
outputCharacters += digits[0];
}
zeroCount = 0;
outputCharacters += digits[Number(d)] + radices[modulus];
}
if (modulus == 0 && zeroCount < 4) {
outputCharacters += bigRadices[quotient];
}
}
outputCharacters += CN_DOLLAR;
}
// Process decimal part if there is:
if (decimal != "") {
for (i = 0; i < decimal.length; i++) {
d = decimal.substr(i, 1);
if (d != "0") {
outputCharacters += digits[Number(d)] + decimals[i];
}
}
}
// Confirm and return the final output string:
if (outputCharacters == "") {
outputCharacters = CN_ZERO + CN_DOLLAR;
}
if (decimal == "") {
outputCharacters += CN_INTEGER;
}
outputCharacters = outputCharacters;
if (CN_SYMBOL != "")
outputCharacters = CN_SYMBOL + outputCharacters;
return outputCharacters;
}
function openFullWin(url) {
var fullwin=window.open(url,"FullWin","toolbar=no,location=no,directories=no,status=no,menubar=no,scrollbars=yes,resizable=yes");
fullwin.moveTo(0, 0);
fullwin.resizeTo(screen.width, screen.height-25);
fullwin.focus();
return false;
}
function openDefaultWin(url) {
var fullwin=window.open(url,"DefaultWin","toolbar=yes,location=yes,directories=no,status=yes,menubar=yes,scrollbars=yes,resizable=yes");
fullwin.moveTo(0, 0);
fullwin.resizeTo(screen.width, screen.height-25);
fullwin.focus();
return false;
}
//获取字符串长度,如果为中文则长度 + 1
function strLength(str){
var len = str.length;
var arr=str.match(/[^\x00-\x80]/ig);
if (arr!= null)
len += arr.length;
return len;
}
//屏蔽错误
window.onerror = function() { return false;}