找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 295|回复: 0
打印 上一主题 下一主题

基于PHP+Ajax实现表单验证的详解

[复制链接]

2588

主题

2588

帖子

7694

积分

论坛元老

Rank: 8Rank: 8

积分
7694
跳转到指定楼层
楼主
发表于 2018-2-14 08:16:33 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            一,利用键盘响应,在不刷新本页面的情况下验证表单输入是否合法
用户通过onkeydown和onkeyup事件来触发响应事件。使用方法和onclick事件类似。onkeydown表示当键盘上的键被按下时触发,onkeyup和它正好相反,当键盘上的键被按下又抬起时触发。
两种常用调用方法:
(1)将事件添加到页面元素中,当用户输入完信息后,单击任意键,onkeydown事件被触发,并调用refer()函数。
这种方法最简单,最直接,格式如下:
[U]复制代码[/U] 代码如下:
  
(2)通过window.onload加载,当页面被载入时,事件被载入。当用户输入信息时,每输入一个字母,都将触发该事件,在该事件调用的函数中,对用户输入信息进行判断。
[U]复制代码[/U] 代码如下:
window.onload = function(){
$('regname').onkeydown = function (){
  name = $('regname').value;
}
}
使用onkeydown事件还可以实现对特定键的控制,包括键(event.keyCode==13)、空格键(event.keyCode==32)、键、键等所有的按键,这是通过在onkeydown事件中使用keyCode属性来实现的。KeyCode属性能够知道用户按下的是哪个键。

二,注册信息验证
通用函数,返回被触发的id元素对象
[U]复制代码[/U] 代码如下:
function $(id){
return document.getElementById(id);
}
window.onload事件,表示当前窗口被载入时触发。function(){...}表示当前页面被载入时所要进行的操作。
window.onload = function(){
...
}
function()函数解析;
首先将焦点定位到用户名文本框,方便用户操作。接下来声明了5个变量,这5个变量代表了5个要检测的数据的结果。当检测数据为合格时,将变量值设为"yes".
[U]复制代码[/U] 代码如下:
$('regname').focus();
var cname1,cname2,cpwd1,cpwd2;  //声明了5个变量,表示要检测的5项数据chkreg()函数是每一次触发键盘事件后都要调用的,该函数判断5个变量的值,只有当所有变量都为"yes"时,注册按钮才会被激活。
function chkreg(){
if((cname1 == 'yes') && (cname2 == 'yes') && (cpwd1 == 'yes') && (cpwd2 == 'yes')){
  $('regbtn').disabled = false;
}else{
  $('regbtn').disabled = true;
}
}
下面验证用户名,当用户输入注册名称时,该函数会把用户的每次输入都做一下正则判断,并根据结果设置不同的cname1的值。
[U]复制代码[/U] 代码如下:
$('regname').onkeyup = function (){
name = $('regname').value;  //获取注册名称
cname2 = '';
if(name.match(/^[a-zA-Z_]*/) == ''){
  $('namediv').innerHTML = '
必须以字母或下划线开头
';
  cname1 = '';
}else if(name.length
当用户名文本框失去焦点时,即用户输入完毕转到页面中其他元素的时候,将检测用户名是否重复。用户名判断使用Ajax技术调用了chkname.php(该页面用户名验证代码稍后贴出)并根据chkname.php的返回值在div标签中显示判断结果。
[U]复制代码[/U] 代码如下:
$('regname').onblur = function(){
name = $('regname').value;  //获取注册名称
if(cname1 == 'yes'){ //当用户名称的格式输入合格后才进行这一步
  xmlhttp.open('get','chkname.php?name='+name,true);  //open()创建XMLHttpRequest初始化连接,Ajax创建新的请求
  xmlhttp.onreadystatechange = function(){  //当指定XMLHttpRequest为异步传输时(false),发生任何状态的变化,该对象都会调用onreadystatechange所指定的函数
   if(xmlhttp.readyState == 4){  //XMLHttpRequest处理状态,4表示处理完毕
    if(xmlhttp.status == 200){ //服务器响应的HTTP代码,200表示正常
     var msg = xmlhttp.responseText;  //获取响应页的内容
     if(msg == '1'){  //chkname.php页面查找数据库,数据库没有该用户返回1
      $('namediv').innerHTML="
恭喜您,该用户名可以使用!
";
      cname2 = 'yes';
     }else if(msg == '2'){ //数据库存在该用户返回0
      $('namediv').innerHTML="
用户名被占用!
";
      cname2 = '';
     }else{
      $('namediv').innerHTML="
"+msg+"
";
      cname2 = '';
     }
    }
   }
  }
  xmlhttp.send(null);
  chkreg(); //检测是否激活注册按钮
}
}
验证密码,验证密码时,除了可以限制密码的长度外,还可以判断密码的强度。
[U]复制代码[/U] 代码如下:
$('regpwd1').onkeyup = function(){
pwd = $('regpwd1').value;
pwd2 = $('regpwd2').value;
if(pwd.length = 6 && pwd.length
二次密码判断比较简单,只要判断第二次输入密码是否和第一次输入相等。
[U]复制代码[/U] 代码如下:
$('regpwd2').onkeyup = function(){
pwd1 = $('regpwd1').value;
pwd2 = $('regpwd2').value;
if(pwd1 != pwd2){
  $('pwddiv2').innerHTML = '
两次密码不一致!
';
  cpwd2 = '';
}else{
  $('pwddiv2').innerHTML = '
密码输入正确
';
  cpwd2 = 'yes';
}
chkreg();
}
上面是必须填写信息,如果用户希望填写更详细的资料,可单击"详细资料按钮"
[U]复制代码[/U] 代码如下:
$('morebtn').onclick = function(){
if($('morediv').style.display == ''){
  $('morediv').style.display = 'none';
}else{
  $('morediv').style.display = '';
}
}
E-mail格式验证,输入字符串中必须包含@和.,同时这两个字符串的位置既不能在首尾也不能连在一起
[U]复制代码[/U] 代码如下:
$('email').onkeyup = function(){
emailreg = /^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/;
$('email').value.match(emailreg);
if($('email').value.match(emailreg) == null){
  $('emaildiv').innerHTML = '
错误的email格式
';
  cemail = '';
}else{
  $('emaildiv').innerHTML = '
输入正确
';
  cemail = 'yes';
}
chkreg();
}
三,检测用户名(chkname.php)
[U]复制代码[/U] 代码如下:
getRowsNum($sql);
if($num == 1){
$reback = '2';
}else if($num == 0){
$reback = '1';
}else{
$reback = $conne->msg_error();
}
echo $reback;
?>
四,XMLHttpRequest函数初始化
[U]复制代码[/U] 代码如下:
// JavaScript Document
var xmlhttp = false;
if (window.XMLHttpRequest) {          //Mozilla、Safari等浏览器
xmlhttp = new XMLHttpRequest();
}
else if (window.ActiveXObject) {         //IE浏览器
try {
  xmlhttp = new ActiveXObject("Msxml2.XMLHTTP");
} catch (e) {
  try {
   xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
    } catch (e) {}
}
}
            
            
您可能感兴趣的文章:
  • PHP+Ajax异步通讯实现用户名邮箱验证是否已注册( 2种方法实现)
  • PHP生成各种常见验证码和Ajax验证过程
  • PHP与Ajax相结合实现登录验证小Demo
  • php+ajax注册实时验证功能
  • PHP+Ajax实现验证码的实时验证
  • PHP+Ajax验证码验证用户登录
  • Ajax提交表单时验证码自动验证 php后端验证码检测
  • thinkphp验证码的实现(form、ajax实现验证)
  • Ajax和PHP正则表达式验证表单及验证码
  • php注册系统和使用Xajax即时验证用户名是否被占用
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端