当前位置: 移动技术网 > IT编程>开发语言>JavaScript > 表单提交验证类

表单提交验证类

2019年07月31日  | 移动技术网IT编程  | 我要评论
 >屏蔽功能类

1.1 屏蔽键盘所有键
<script language="javascript">
<!--
function document.onkeydown(){
   event.keycode = 0;
   event.returnvalue = false;
}
-->
</script>

1.2 屏蔽鼠标右键

在body标签里加上oncontextmenu=self.event.returnvalue=false

或者

<script language="javascript">
<!--
function document.oncontextmenu() 

  return false; 

-->
</script>

function nocontextmenu()

    if(document.all) {
        event.cancelbubble=true;
        event.returnvalue=false; 
        return false; 
    }
}

或者

<body onmousedown="rclick()" oncontextmenu= "nocontextmenu()">

<script language="javascript">
<!--
function rclick()
{
    if(document.all) {
        if (event.button == 2){
            event.returnvalue=false;
        }
    }
}
-->
</script>


1.3 屏蔽 ctrl+n、shift+f10、f5刷新、退格键

<script language="javascript">
<!--
  //屏蔽鼠标右键、ctrl+n、shift+f10、f5刷新、退格键
function window.onhelp(){return false} //屏蔽f1帮助
function keydown(){
  if ((window.event.altkey)&&
      ((window.event.keycode==37)||   //屏蔽 alt+ 方向键 ←
       (window.event.keycode==39))){  //屏蔽 alt+ 方向键 →
     alert("不准你使用alt+方向键前进或后退网页!");
     event.returnvalue=false;
     }

     /* 注:这还不是真正地屏蔽 alt+ 方向键,
     因为 alt+ 方向键弹出警告框时,按住 alt 键不放,
     用鼠标点掉警告框,这种屏蔽方法就失效了。以后若
     有哪位高手有真正屏蔽 alt 键的方法,请告知。*/

  if ((event.keycode == 8) && 
      (event.srcelement.type != "text" && 
      event.srcelement.type != "textarea" && 
      event.srcelement.type != "password") ||           //屏蔽退格删除键   
      (event.keycode==116)||                            //屏蔽 f5 刷新键
      (event.ctrlkey && event.keycode==82)){            //ctrl + r
     event.keycode=0;
     event.returnvalue=false;
     }
  if ((event.ctrlkey)&&(event.keycode==78))   //屏蔽 ctrl+n
     event.returnvalue=false;
  if ((event.shiftkey)&&(event.keycode==121)) //屏蔽 shift+f10
     event.returnvalue=false;
  if (window.event.srcelement.tagname == "a" && window.event.shiftkey) 
      window.event.returnvalue = false;  //屏蔽 shift 加鼠标左键新开一网页
  if ((window.event.altkey)&&(window.event.keycode==115)){ //屏蔽alt+f4
      window.showmodelessdialog("about:blank","","dialogwidth:1px;dialogheight:1px");
      return false;}
  }
 /* 另外可以用 window.open 的方法屏蔽 ie 的所有菜单
第一种方法:
  window.open("你的.htm", "","toolbar=no,location=no,directories=no,menubar=no,scrollbars=no,resizable=yes,status=no,top=0,left=0")
第二种方法是打开一个全屏的页面:
  window.open("你的.asp", "", "fullscreen=yes")
 */
//-->
</script>

1.4屏蔽浏览器右上角“最小化”“最大化”“关闭”键

<script language=javascript>
function window.onbeforeunload()
{
  if(event.clientx>document.body.clientwidth&&event.clienty<0||event.altkey)
  {
    window.event.returnvalue = "";
  }
}
</script>

或者使用全屏打开页面

<script language="javascript">
<!--
window.open(www.32pic.com,"32pic","fullscreen=3,height=100, width=400, top=0, left=0, toolbar=no, menubar=no, scrollbars=no, resizable=no,location=no, status=no");
-->
</script>

注:在body标签里加上onbeforeunload="javascript:return false"(使不能关闭窗口)

1.5屏蔽f5键

<script language="javascript">
<!--
function document.onkeydown() 

    if ( event.keycode==116) 
    { 
        event.keycode = 0; 
        event.cancelbubble = true; 
        return false; 
    }
}
-->
</script>

1.6屏蔽ie后退按钮

在你链接的时候用 <a href="javascript:location.replace(url)">

1.7屏蔽主窗口滚动条

在body标签里加上 style="overflow-y:hidden"

1.8 屏蔽拷屏,不断地清空剪贴板

在body标签里加上onload="setinterval('clipboarddata.setdata(\'text\',\'\')',100)"

1.9 屏蔽网站的打印功能

<style>
@media print {
   * { display: none }
}
</style>

1.10 屏蔽ie6.0 图片上自动出现的保存图标

方法一:
<meta http-equiv="imagetoolbar" content="no">
方法二:
<img galleryimg="no">

1.11 屏蔽页中所有的script

<noscrript></noscript>

<script language="javascript">
<!--
function checkform()
{
if (document.form.name.value.length == 0) {
   alert("请输入您姓名!");
   document.form.name.focus();
   return false;
}
   return true;
}
-->
</script>

2.2 比较两个表单项的值是否相同

<script language="javascript">
<!--
function checkform()
if (document.form.pwd.value != document.form.pwd_again.value) {
   alert("您两次输入的密码不一样!请重新输入.");
   document.adduser.pwd.focus();
   return false;
}
   return true;
}
-->
</script>

2.3 表单项只能为数字和"_",用于电话/银行帐号验证上,可扩展到域名注册等

<script language="javascript">
<!--
function isnumber(string)

    var letters = "1234567890-"; //可以自己增加可输入值
    var i;
    var c;
      if(string.charat( 0 )=='-')
 return false;
      if( string.charat( string.length - 1 ) == '-' )
          return false;
     for( i = 0; i < string.length; i ++ )
     {
          c = string.charat( i );
   if (letters.indexof( c ) < 0)
          return false;
}
     return true;
}
function checkform()
{
    if(! isnumber(document.form.tel.value)) {
  alert("您的电话号码不合法!");
         document.form.tel.focus();
         return false;
}
return true;
}
-->
</script>


2.4 表单项输入数值/长度限定

<script language="javascript">
<!--
function checkform() 
{
    if (document.form.count.value > 100 || document.form.count.value < 1)
{
 alert("输入数值不能小于零大于100!");
 document.form.count.focus();
 return false;
}
    if (document.form.message.value.length<10)
{
 alert("输入文字小于10!");
 document.form.message.focus();
 return false;
}
return true;
}
//-->
</script>

2.5 中文/英文/数字/邮件地址合法性判断

<script language="javascript">
<!--

function isenglish(name) //英文值检测
{
 if(name.length == 0)
  return false;
 for(i = 0; i < name.length; i++) {
  if(name.charcodeat(i) > 128)
   return false;
 }
 return true;
}

function ischinese(name) //中文值检测
{
 if(name.length == 0)
  return false;
 for(i = 0; i < name.length; i++) {
  if(name.charcodeat(i) > 128)
   return true;
 }
 return false;
}

function ismail(name) // e-mail值检测
{
 if(! isenglish(name))
  return false;
 i = name.indexof("@");
 j = name.lastindexof("@");
 if(i == -1)
  return false;
 if(i != j)
  return false;
 if(i == name.length)
  return false;
 return true;
}

function isnumber(name) //数值检测
{
 if(name.length == 0)
  return false;
 for(i = 0; i < name.length; i++) {
  if(name.charat(i) < "0" || name.charat(i) > "9")
   return false;
 }
 return true;
}

function checkform()
{
 if(! ismail(form.email.value)) {
  alert("您的电子邮件不合法!");
  form.email.focus();
  return false;
 }
 if(! isenglish(form.name.value)) {
  alert("英文名不合法!");
  form.name.focus();
  return false;
 }
 if(! ischinese(form.cnname.value)) {
  alert("中文名不合法!");
  form.cnname.focus();
  return false;
 }
 if(! isnumber(form.publiczipcode.value)) {
  alert("邮政编码不合法!");
  form.publiczipcode.focus();
  return false;
 }
 return true;
}
//-->
</script>

2.6 限定表单项不能输入的字符

<script language="javascript">
<!--

function contain(str,charset)// 字符串包含测试函数
{
  var i;
  for(i=0;i<charset.length;i++)
  if(str.indexof(charset.charat(i))>=0)
  return true;
  return false;
}

function checkform()
{
 if ((contain(document.form.name.value, "%\(\)><")) || (contain(document.form.message.value, "%\(\)><")))
{
  alert("输入了非法字符");
  document.form.name.focus();
  return false;
}
  return true;
}
//-->
</script>

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网