简介

    51cto的程序员应该都有sina微博吧!你会发现当你更改新浪会员名称,输入用户名Tab后,光标焦点移动到密码输出框时,用户名输出框的后面,就已经显示出了验证。验证信息是:你的用户名是否唯一,因为新浪微博和腾讯微博不一样,她的会员用户名都是唯一的,这样好将用户区分开,达到没有重名的目的。

    如果用户名已被注册,就显示用户名已存在,用户名还没被注册,就显示用户名可用

    wKiom1Q1B7_Bl6YAAACNfssa4MU170.jpg

    实现原理

       1、当光标焦点移动到别处时,触发jswindow.onblur事件,调用Ajax对象

       2、将用户名框内的字符串(document.getElementById(id).value)提交到后台页面

       3、与相应数据库里的数据进行比对,再将比对结果返回到界面上,呈现我们面前的就是上面那样的画面。

    

    好处:实现页面的局部刷新,在全部提交到后台前,提前验证并给出结果,提高了输出的效率。

 

    下面不说那么多了,直接上代码:

    demo.html    前端页面  就一个用户名输出框(很简单吧!关键是弄懂原理)

    public.js    封装了对不同浏览器、创建不同Ajax对象的方法

    ajax.js      Ajax对象的封装、方法的实现

    demo.php     后台页面  主要实现接收数据、选择并连接数据库、判断接收的数据与数据库比对

    

    demo.html

        <head>
            <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
            <title>用户输入</title>
            <script language="javascript" src="public.js"></script>
            <script language="javascript" src="ajax.js"></script>
        </head>
    
        <body οnlοad="response()">
            <form>
                 用户名:
                 <input type="text" name="username" id="username"/><span id="msg"></span>
            </form>
        </body>

    

    public.js

        function createxhr(){
            try{return new ActiveXObject("Microsoft.XMLHTTP")}catch(e){}
            try{return new XMLHttpRequest}catch(e){}
            alert("请更换浏览器");
        }
        //获取DOM对象的id值
        function $(id){
            return document.getElementById(id);
        }

    

    ajax.js 

        function response(){        
            $('username').onblur = function(){
                var uname = this.value; //面向对象编程,this指代"$('username')"
                var xhr = createxhr();
                //应用getTime()方法解决IE缓存问题
                var url = "demo.php?username="+uname+'&_'+new Date().getTime();
                xhr.open('get',url);
                xhr.onreadystatechange = function(){
                    if (xhr.readyState == 4 && xhr.status == 200){
                        var value = xhr.responseText;
                        if (value == 1){
                            $('msg').innerHTML = '<font color = red>用户名已存在</font>';
                        }else{
                            $('msg').innerHTML = '<font color = green>用户名可用</font>';
                        }
                    }
                };
                xhr.send(null);
            };
        };

    

    demo.php

        //接收传递数据
        $username = $_GET['username'];
        
        //连接、选择数据库
        mysql_connect('localhost','root','111111');
        mysql_select_db('shop');
        mysql_query('set names gb2312');
        //sql语句、执行
        $sql = "select * from users where username='$username'";
        $result = mysql_query($sql);
        $num = mysql_num_rows($result);//获得结果集的行数
        
        //判断结果集行数
        if($num>0){
            echo 1;
        }else{
            echo 2;
        }

    查看结果:

        

wKiom1Q1C2bhrI4VAAA6_K3wbYw343.jpg

wKiom1Q1C2ahv13YAAA9kvH_6yY902.jpg