常用js函数

/**/
/*------------------------------------------------------------
 弹出时间选择小控件
 inputid--文本框name
 initDate--初始日期,为空时是当前时间
 startYear--日期范围的开始日期
 endYear--日期范围的结束日期
 使用例子onClick="dateDlg(end,'1999-11-12','1980','2010')"
  ------------------------------------------------------------
*/

function  dateDlg(inputid,initDate,startYear,endYear)
{
 
var pattern = /^(19|20)([0-9]){2}$/;
 flag
=pattern.test(startYear);
 
if(!flag)startYear=1900;
 flag
=pattern.test(endYear);
 
if(!flag)endYear=2050;
 
if(inputid.value==null||inputid.value=='')
  
{
   
if(initDate==null||initDate=='')
   
{
     currentDate 
= new Date();  
   }

   
else{
    currentDate 
= initDate;
   }

  }

 
else
   currentDate 
= inputid.value;
  }

 
var arguments = new Array(startYear,endYear,0,0,0)

 
var pattern = /^(19|20)([0-9]){2}-(0[1-9]|1[0-2])-(0[1-9]|[1-2][0-9]|3[0-1])$/;
 flag
=pattern.test(currentDate);
 
if(flag)
 
{
  iYear
=currentDate.substring(0,4);
  iMonth
=currentDate.substring(5,7);
  iDay
=currentDate.substring(8,10);
  arguments 
= new Array(startYear,endYear,iYear,iMonth,iDay)
 }

 showx 
= event.screenX - event.offsetX + 18;
 showy 
= event.screenY - event.offsetY - 210;

 
var features =
  'dialogWidth:'  
+ 192 + 'px;' +
  'dialogHeight:' 
+ 210 + 'px;' +
  'dialogLeft:'   
+ showx     + 'px;' +
  'dialogTop:'    
+ showy     + 'px;' +
  'directories:no; localtion:no; menubar:no; status
=no; toolbar=no;scrollbars:yes;Resizeable=no';
 retval 
= window.showModalDialog("../js/calendar.htm", arguments , features );
 
var calctrl = eval(inputid)
 
if( retval != null ){
  calctrl.value 
= retval;
 }
else{
  
//alert("canceled");
 }

}


/*------------------------------------------------------------
 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, "");
}

/*------------------------------------------------------------
 判断密码是否有单引号
  ------------------------------------------------------------
*/

function  isNotYinhao(s)
{   
    
var yin;
 
var temp="'";
 
for(yin=0; yin < s.length; yin++ ) 
 

  
var ch = s.charAt(yin);
  
if(temp.indexOf(ch)>=0)
  
{
   
return true;
  }

 }

 
return false;
}


/*------------------------------------------------------------
 定义变量
  ------------------------------------------------------------
*/

var  i,j;

/*------------------------------------------------------------
 和当前日期比较,如果当前日期大于输入日期则提示
 end----输入日期
 s----提示信息
 使用例子onClick="compareDate(end,'选择日期不能在今天之前!')" 
  ------------------------------------------------------------
*/

function  compareDate(end,s) {
var a=new Date();
var b=end.value;
if(((Number(a.getYear())-Number(b.substring(0,4)))*356+
       (Number(a.getMonth())
-Number(b.substring(5,7))+1)*31+
    (Number(a.getDate())
-Number(b.substring(8,10))))>0)
 
{
  alert(s);
  end.focus();
 }

}



/*------------------------------------------------------------
 两个时间进行比较,当开始日期大于结束日期则提示
 startDate----开始日期
 endDate------结束日期
 使用例子onClick="compareTwoDate(startDate,endDate,'开始日期不能大于结束日期!')" 
  ------------------------------------------------------------
*/

function  compareTwoDate(startDate,endDate,s)
{
var a=startDate.value;
var b=endDate.value;
if(((Number(a.substring(0,4))-Number(b.substring(0,4)))*356+
       (Number(a.substring(
5,7))-Number(b.substring(5,7)))*31+
    (Number(a.substring(
8,10))-Number(b.substring(8,10))))>0)
 
{
  alert(s);
  startDate.focus();
 }

}


/*------------------------------------------------------------
 判断是否为数字类型,如不是数字类型则提示
 text-------输入文本
 name-------提示的名字
 使用例子onBlur="compareTwoDate(this,'电话号码')" 
  ------------------------------------------------------------
*/

function  isNumber(text,name)
{
  
var temp="0123456789";
   
for(j=0; j<text.value.length; j++ ) 
   
{    
     
var ch = text.value.Trim().charAt(j);
  
if(temp.indexOf(ch)==-1)
  
{
   alert(name
+"应为数字类型!");
   text.focus();
   
return true;
  }
  
   }

}


/*------------------------------------------------------------
 判断两次密码输入是否一致
 text-------新密码
 name-------再次输入新密码
 使用例子checkPassword(form1.newpass,form1.newpass1) 
  ------------------------------------------------------------
*/

function  checkPassword(text,text1)
{
  
var newpass=text.value.Trim();
  
var newpass1=text1.value.Trim();
  
if(newpass!=newpass1){
    alert(
"两次输入新密码不一致!");
    text.focus();
    
return true;
  }

}



/*------------------------------------------------------------
 判断是否包含非法字符,如含非法字符则提示
 text-------输入文本
 addtemp----除英文和数字外还可包含的字符
 name-------提示的名字
 include----提示中不允许包含的字符
 使用例子onBlur="compareTwoDate(this,'@_','邮件','%*$')" 
  ------------------------------------------------------------
*/

function  isChar(text,addtemp,name,include)
{
  
var temp="0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"+addtemp;
   
for(j=0; j<text.value.length; j++ ) 
   
{    
     
var ch = text.value.Trim().charAt(j);
  
if(temp.indexOf(ch)==-1)
  
{
   alert(name
+"中不允许包含'"+include+"'等字符!");
   text.focus();
   
break
  }
  
   }

}


/*------------------------------------------------------------
 判断输入的是否为电子邮件,如含非法字符则提示
 text-------输入的电子邮件
 使用例子onBlur="isEmail(this)" 
  ------------------------------------------------------------
*/

function  isEmail(text)
{   
 
var email=text.value.Trim();
 
var m=email.indexOf("@");
 
var n=email.indexOf(".");
 
if(email!="")
 
{
  
if(m<1||m>email.length-3)
  
{
   alert(
"请输入正确的电子邮件格式!");
   text.focus();
   
return true;
  }

  
else if(n<m+2||n>email.length-2)
  
{
   alert(
"请输入正确的电子邮件格式!");
   text.focus();
   
return true;
  }

 }

}

/*------------------------------------------------------------
 判断输入文本是否为身份证号码,如为不正确则提示
 text-------输入的身份证号码
 使用例子onBlur="isPid(this)" 
  ------------------------------------------------------------
*/

function  isPid(text)
{
 
var pid=text.value.Trim();
 
var temp="0123456789";
 
var temp1="0123456789xX";
 
if(pid!=""){
 
if(pid.length==15)
 
{
     
for(j=0; j<15; j++ ) 
     
{    
   
var ch = pid.charAt(j);
   
if(temp.indexOf(ch)==-1)
   
{
    alert(
"请输入正确的身份证号码!");
    text.focus();
    
break
   }

  }
       
 }

 
else if(pid.length==18)
 
{

     
for(j=0; j<pid.length-1; j++ ) 
     
{    
   
var ch = pid.charAt(j);
   
if(temp.indexOf(ch)==-1)
   
{
    alert(
"请输入正确的身份证号码!");
    text.focus();
    
break
   }

  }
       
  
var ch1 = pid.charAt(pid.length-1);
  
if(temp1.indexOf(ch1)==-1)
   
{
    alert(
"请输入正确的身份证号码!");
    text.focus();
   }
    
 }

 
else{
  alert(
"身份证号码的应为15位或18位!");
  text.focus();
 }
}

}


/*------------------------------------------------------------
 判断输入文本是否为空,如为空则提示
 text-------输入文本
 使用例子onBlur="isNull(this,'姓名')" 
  ------------------------------------------------------------
*/

function  isNull(text,name)
{
 
if(text.value.Trim()==null||text.value.Trim()=="")
 
{
  alert(name
+"不能为空!");
  text.focus();
  
return true;
 }

}


/*------------------------------------------------------------
 获取文本框长度,中文作为两个字符处理
 text-------输入文本
 使用例子getLength(form1.name) 
  ------------------------------------------------------------
*/

function  getLength(text)
{
 
var temp="0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
 temp
=temp+"`~!@#$%^&*()_+|-=/[]{};':,./<>?/"";
 temp=temp+
"·~!◎#¥%……※×()——+§-=÷【】『』;‘:“,。、《》?";
 var len = text.value.Trim().length;
 for(j=0;j<text.value.Trim().length;j++)
 {
  var ch= text.value.Trim().charAt(j);
  if(temp.indexOf(ch)==-1){
  len++;
  }
 }
 return len;
}

/*------------------------------------------------------------
 lengthEquals(text,name,num)    相等长度
 lengthless(text,name,num)      长度不少于
 lengthmore(text,name,num)      长度不大于
 获取文本框长度,中文作为两个字符处理
 text-------输入文本
 使用例子getLength(form1.name,'姓名',8) 
  ------------------------------------------------------------*/
function lengthEquals(text,name,num)
{
 if(getLength(text)!=num)
 {
  alert(
"请输入"+num+""+name+"!")
  text.focus();
  return true;
 }
}

function lengthless(text,name,num)
{
 if(getLength(text)<num)
 {
  alert(name+
"不能少于"+num+"!")
  text.focus();
  return true;
 }
}
function lengthmore(text,name,num)
{
 if(getLength(text)>num)
 {
  alert(name+
"不能大于"+num+"!")
  text.focus();
  return true;
 }
}

/*------------------------------------------------------------
 判断bodyText输入文本是否为空,如为空则提示
 bodyText-------输入文本
 使用例子onBlur=
"isNullBody('姓名')" 
  ------------------------------------------------------------*/
function isNullBody(name)
{
  var bodyText = frames[
"Dvbbs_Composition"].document.body.innerText;
  if(bodyText.length==0) {
      frames[
"Dvbbs_Composition"].focus();
      alert(name+
"不能为空!");
      return true;
  }
}


/*------------------------------------------------------------
 获取文本框长度,中文作为两个字符处理
 bodyText-------输入文本
 使用例子isLengthBody(form1.name) 
  ------------------------------------------------------------*/
function isLengthBody(text,name)
{
    if (text.value.length > 600) {
        frames[
"Dvbbs_Composition"].focus();
        alert(name+
"不能超过600!");
 return true;
    }
}


/*------------------------------------------------------------
 检查是否含有”'“号
        有,则返回true
        无, 则返回false
  ------------------------------------------------------------*/
function isTheChar(text,name)
{
    var re= /'/g;
    var arr = text.match(re);
    if (arr == null)
        return false;
    else
        return true;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 好的,那我们可以用一个名为 "util" 的对象来封装这些函数,例如: ``` const util = { add: function(a, b) { return a + b; }, subtract: function(a, b) { return a - b; }, multiply: function(a, b) { return a * b; }, divide: function(a, b) { return a / b; } }; ``` 然后你就可以通过访问 "util.add(a, b)" 来使用加法函数了。你也可以继续往这个对象里添加其他常用函数。 需要注意的是,以上代码假设你使用的是 ES6 语法,如果你使用的是 ES5 语法,你需要把 "function" 换成 "var"。 ### 回答2: 封装一个常用JavaScript函数集合是为了提高开发效率和代码的重用性。这个函数集合可以包含各种常用的功能函数,例如: 1. 获取URL参数值:可以封装一个函数,通过传入参数名,返回对应的URL参数值。比如,可以使用window.location.search获取URL参数字符串,然后再使用正则表达式或其他方法找到对应的参数值。 2. 时间格式化:封装一个函数,将时间对象转换为指定格式的字符串。比如,可以使用Date对象的方法获取年月日、时分秒等信息,然后根据需要进行格式化输出。 3. 随机数生成:可以封装一个函数,生成指定范围内的随机整数或随机浮点数。比如,可以使用Math.random函数生成0到1之间的随机数,然后根据需要进行相应的运算转换。 4. 数组元素查找:可以封装一个函数,根据指定条件在数组中查找元素,并返回符合条件的元素或索引值。比如可以使用Array的filter方法根据判定函数找到满足条件的元素。 5. 数据类型判断:可以封装一个函数,判断变量的数据类型并返回相应的字符串表示。比如,可以使用typeof运算符判断基本数据类型,使用Array.isArray判断数组类型,使用Object.prototype.toString判断复杂数据类型。 6. 字符串截取:可以封装一个函数,对字符串进行截取操作,根据指定参数截取指定长度的字符串,同时提供省略号等处理方式。 7. 表单验证:可以封装一些常用的表单验证函数,例如验证邮箱、手机号码、用户名等。这些函数可以使用正则表达式或其他验证方式进行验证,以提高代码的可读性和可维护性。 以上只是一些常见的封装函数示例,实际的常用函数集合可以根据具体需求进行扩展和定制。 ### 回答3: 常用JavaScript函数集合可以提供一组常见功能的封装,以便在开发过程中更便捷地调用这些函数。下面是一个封装了一些常用功能的常用JavaScript函数集合例子: 1. 获取URL参数:这个函数可以从URL中获取指定参数的值并返回。可以通过传递参数名来获取不同的参数值。 2. 格式化日期:这个函数可以将日期对象或日期字符串格式化为指定的日期格式。可以通过参数来指定所需的日期格式。 3. 判断空值:这个函数可以判断一个变量是否为空(包括未定义、null、空字符串等),返回true或false。 4. 随机数生成:这个函数可以生成一定范围内的随机数,可以通过传递参数指定范围。 5. 数组去重:这个函数可以对数组进行去重操作,并返回去重后的数组。 6. 节流函数:这个函数可以控制函数的频率,在指定的时间间隔内只执行一次。 7. 深度拷贝对象:这个函数可以实现深度拷贝一个对象,返回一个拷贝后的新对象。 8. 字符串截取:这个函数可以截取指定长度的字符串,并在结尾添加省略号。 9. 图片预加载:这个函数可以实现图片的预加载,防止图片未加载完全时导致页面闪烁。 10. 防抖函数:这个函数可以控制函数的执行频率,在指定的时间间隔内,只有最后一次触发才执行。 这些是常用JavaScript函数集合的一些例子,通过封装这些功能,可以使开发过程更高效、便捷。可以根据需要自定义封装适合自己的常用功能函数集合。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值