欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS校驗與最終登陸界面功能完整示例

 更新時間:2020年01月13日 10:03:28   作者:qq_42412646  
這篇文章主要介紹了JS校驗與最終登陸界面功能,結(jié)合完整實例形式詳細分析了JavaScript登錄界面校驗功能與正則驗證相關(guān)操作技巧,需要的朋友可以參考下

本文實例講述了JS校驗與最終登陸界面功能。分享給大家供大家參考,具體如下:

<html>
    <head>
        <title>注冊頁面</title>
        <meta charset="UTF-8"/>
        <script type="text/javascript">
//            校驗用戶名
            function checkUname(){
//                獲取用戶名對象
                var uname=document.getElementById("uname").value;
//                創(chuàng)建校驗正則表達式判斷條件
                var reg=/^[\u4e00-\u9fa5]{2,4}$/;     //其中前面的一部分是漢字的正則表達式,后面的是漢字的合法范圍,(第一次因為,正則表達式寫錯了)
//                獲取后面的提示字
                var nameSpan=document.getElementById("nameSpan"); //span是一個沒有特殊含義的自定義標(biāo)簽用來輔助設(shè)計
//                進行校驗
                if(uname=="" || uname ==null){
                    nameSpan.innerHTML="用戶名不能為空";
                    nameSpan.style.color="red";
                    return false;
                }else if(reg.test(uname)){
                    nameSpan.innerHTML="用戶名合法";
                    nameSpan.style.color="green";
                    return true;
                }else{
                    nameSpan.innerHTML="用戶名不合法";
                    nameSpan.style.color="red";
                    return false;
                }
            }
            function checkPassword(){
//                獲取用戶名對象
                var password1=document.getElementById("pws1").value; //我們是通過對象的value值(文本輸入框的內(nèi)容)進行判斷的
//                創(chuàng)建校驗正則表達式判斷條件
                var reg=/^[a-z]\w{4,8}$/;     //首位為字母,后面為數(shù)字4到8位 ()
//                獲取后面的提示字
                var pwsSpan=document.getElementById("passwordSpan"); //span是一個沒有特殊含義的自定義標(biāo)簽用來輔助設(shè)計
//                進行校驗
                if(password1=="" || password1 ==null){
                    pwsSpan.innerHTML="*密碼不能為空";
                    pwsSpan.style.color="red";
                    return false;
                }else if(reg.test(password1)){
                    pwsSpan.innerHTML="*密碼合法";
                    pwsSpan.style.color="green";
                    return true;
                }else{
                    pwsSpan.innerHTML="*密碼不合法";
                    pwsSpan.style.color="red";
                    return false;
                }
//                return password1.value;
                checkPassworded();   //在失去焦點的時候(調(diào)用該函數(shù)時,也進行確認密碼的校驗),如果沒有這個操作,當(dāng)重新修改用戶密碼時,其不會在進行確認密碼(即修改密碼后即使不相同也不會報錯)
            }
            //            校驗確定密碼
            function checkPassworded(){
//            獲取確認密碼對象
                var password2=document.getElementById("pws2").value;
//            獲取第一次密碼對象,以進行比較
                var password1=document.getElementById("pws1").value;
//                獲取提示語的對象
                var pwslSpan=document.getElementById("passwordlSpan");
//                reg=checkPassword();
//       if(reg="" || reg=null)         //沒能實現(xiàn)
                if(password2=="" || password2==null){   //null就是字符串類型,表示空字符串
                    pwslSpan.innerHTML="*確認密碼不能為空";
                    pwslSpan.style.color="red";
                    return false;
                }else if(password1 == password2){      
                    pwslSpan.innerHTML="*兩次密碼相同";
                    pwslSpan.style.color="green";
                    return true;
                }else{
                    pwslSpan.innerHTML="*兩次密碼不相同";
                    pwslSpan.style.color="red";
                    return false;
                }
            }
//--------------------------------------------------------------------------------------------------------
//    考慮到有很多的校驗方法都用到相同的方法和結(jié)構(gòu),所以我們在此對其進行封裝
            function checkAll(id,reg){      //封裝的基本思想:相同的直接寫入,不同的利用參數(shù)轉(zhuǎn)換
                //接收傳遞的對象
                var inp=document.getElementById(id);   //我們傳的參數(shù)是帶雙引號的
                var ie=inp.value;           //我們通過對象的值進行判斷
                var alt=inp.alt;             //通過對象來獲得其對應(yīng)的一些值
                //接收傳遞的提示框?qū)ο?
                var span=document.getElementById(id+"Span");
                if(ie=="" || ie==null){
                    span.innerHTML=alt+"不能為空";
                    span.style.color="red";
                    return false;
                }else if(reg.test(ie)){
                    span.innerHTML=alt+"合法";
                    span.style.color="green";
                    return true;
                }else{
                    span.innerHTML=alt+"不合法";
                    span.style.color="red";
                    return false;
                }
            }
//            手機號的校驗
            function checkPhone(){
                return checkAll("phone",/^1[3,4,5,7,8]\d{9}$/);
            }
//            郵箱的校驗
            function checkMail(){
                return checkAll("mail",/^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(.[a-zA-Z0-9_-])+$/);
            }
//            添加驗證碼
            function checkCode(){
//                獲取驗證碼填寫對象
                var code=document.getElementById("code1");
//                獲取驗證顯示對象
                var codeSpan=document.getElementById("codeSpan");
                var tag=Math.floor(Math.random()*9000+1000);   //產(chǎn)生四位的整數(shù),Math.floor表示向下取整,
                codeSpan.innerHTML=tag;
            }
//            校驗驗證碼
            function checkCoded(){
//                獲取輸入的驗證碼對象
                var code2=document.getElementById("code1").value;
//                 獲取顯示的驗證碼對象,以進行比較
                var codeSpan1=document.getElementById("codeSpan");
                var code1=codeSpan1.innerHTML;       //通過對象利用其innerHTML屬性進行獲得,其利用value不正確,沒進一步探索
//                獲取提示語的對象
                var codeSpan2=document.getElementById("codeSpan2");
//                alert(code1);       //得到的值是undefined
//                alert(code2);
                if(code2=="" || code2==null){   
                    codeSpan2.innerHTML="*驗證碼不能為空";
                    codeSpan2.style.color="red";
                    return false;
                }else if(code1 == code2){      
                    codeSpan2.innerHTML="*驗證碼相同";
                    codeSpan2.style.color="green";
                    return true;
                }else{
                    codeSpan2.innerHTML="*驗證碼不相同";
                    codeSpan2.style.color="red";
                    return false;
                }
            }
//            校驗選擇框
            function checkSelect(){
//                獲取選擇框?qū)ο?
                var select=document.getElementById("select").value;
//                獲取選擇框提示對象
                var selectSpan=document.getElementById("selectSpan");
//                selectSpan.style.fontSize="15px";
                if(select==0){
                    selectSpan.innerHTML="地址選擇不能為空";
                    selectSpan.style.color="red";
                    return false;
                }else{
                    selectSpan.innerHTML=select;
                    selectSpan.style.color="green";
                    return true;
                }
            }
//            檢測多選框
            function checkFav(){
//                獲取多選框?qū)ο?
                var fav=document.getElementsByName("fav");
//                獲取多選框提示對象
                var favSpan=document.getElementById("favSpan");
                favSpan.style.fontSize="10px";
                for(var i=0;i<fav.length;i++){
                    if(fav[i].checked){ //fav[i]是一個對象,fav[i].checked是一個值
                        favSpan.innerHTML="選擇成功";
                        favSpan.style.color="green";
                        return true;       //選擇成功后直接返回
                    }
                }                 //在整個循環(huán)結(jié)束后都沒有進行選擇,才進行不符合提示
                favSpan.innerHTML="至少選擇一個";
                favSpan.style.color="red";
                return false;
            }
            function checkAgree(){
//                當(dāng)同意公司協(xié)議的時候才能進行提交操作
                document.getElementById("pop").disabled=!document.getElementById("agree").checked;
//                當(dāng)同意公司協(xié)議的時候,對應(yīng)的submit的對應(yīng)值是true,所以我們利用!把disabled的值賦值為false
            }
            function checkSub(){
//                校驗是否可以提交
//                對于所有的校驗函數(shù),只要有一個不滿足條件,就不能提交
                checkUname();
                checkPassword();
                checkPassworded();
                checkPhone();
                checkMail();
                checkCoded();
                checkSelect();
                checkFav();        //當(dāng)所有值都為true的時候才能進行提交,所以對應(yīng)的函數(shù)有返回值,不滿足時返回false,滿足時返回true
                return checkUname()&&checkPassword()&&checkPassworded()&&checkPhone()&&checkMail()&&checkCoded()&&checkSelect()&&checkFav();
            }
        </script>
        <style type="text/css">
            tr,td,table{
                background-color: transparent;
                border 0px;
            }
            span{
                font-size: 10px;
            }
            #codeSpan{
              width: 30px;
              height: 25px;
                font-size: 20px;
                color: black;
                background-size: 100%,100%;      /*后面三行是使背景圖片占滿整個區(qū)域*/
                background-repeat: no-repeat;
                background-image: url(../img/0.jpg);
            }
            #selectSpan{
                font-size: 15px;
            }
            #showdiv{
                width: 30%;
                height: 100%;
                background-image: url(../img/5.jpg);
                background-size: cover;
                background-repeat: no-repeat;
                margin-left: 33%;
            }
            input,select,[type=checkbox],#bigText{
                background-color: transparent;   /* 把一些邊框背景變?yōu)橥该鞯囊燥@示背景*/
            }
        </style>
    </head>
    <body onload="checkCode(),checkSelect(),checkFav()">
        <form action="#" action="get">
            <div align="center" id="showdiv">
            <table border="1px" cellpadding="5px" cellspacing="0px">
                <tr height="29px">
                    <td width="80px">姓名</td>
                    <td width="180px">
                        <input type="text" name="uname" value="" id="uname" onblur="checkUname()"/>
                        <span id="nameSpan"></span>  <!-- 以焦點的有無來進行判斷-->
                    </td>
                </tr>
                <tr height="29px">
                    <td width="80px">郵箱</td>
                    <td width="180px">
                        <input type="text" name="mail" value="" id="mail" alt="郵箱" onblur="checkMail()"/>
                        <span id="mailSpan"></span>
                    </td>
                </tr>
                <tr height="29px">
                    <td width="80px">手機號</td>
                    <td width="180px">      <!--查了很長時間的錯誤,就因為調(diào)用的函數(shù)沒有用""包含,""在外面了-->
                        <input type="text" name="phone" value="" id="phone" alt="手機號" onblur="checkPhone()"/>
                        <span id="phoneSpan"></span>  
                    </td>
                </tr>
                <tr height="31px">
                    <td width="80px">密碼</td>
                    <td width="180px">
                        <input type="password" name="psw" value="" id="pws1" onblur="checkPassword()"/>
                        <span id="passwordSpan"></span>
                    </td>
                </tr>
                <tr height="29px">
                    <td width="80px">確認密碼</td>
                    <td width="180px">
                        <input type="password" name="psw2" value="" id="pws2" onblur="checkPassworded()"/>
                        <span id="passwordlSpan"></span>
                    </td>
                </tr>
                <tr height="31px">
                    <td>性別</td>
                    <td>
                        男<input type="radio" name="sex" value="1" checked="checked" /> 女<input type="radio" name="sex" value="0" />
                    </td>
                </tr>
                <tr height="31px">
                    <td>所在地</td>
                    <td>
                        <select name="" id="select" onchange="checkSelect()">
                            <option value="0"></option>
                            <option value="山東">山東</option>
                            <option value="北京">北京</option>
                            <option value="河南">河南</option>
                        </select>
                        <span id="selectSpan"></span>
                    </td>
                </tr>
                <tr height="31px">
                    <td>愛好</td>
                    <td>               <!--我們對每一個都進行事件觸發(fā)檢驗,因為每個選項都是平等的-->
                        動漫<input type="checkbox" name="fav" id="fav" onclick="checkFav()" value="animation"/>
                        游戲<input type="checkbox" name="fav" id="fav" onclick="checkFav()" value="game" />
                        打球<input type="checkbox" name="fav" id="fav" onclick="checkFav()" value="ball" />
                        <span id="favSpan"></span>
                    </td>
                </tr>
                <tr height="31px">
                    <td>個人簡介</td>
                    <td>
                        <textarea name="introduction" rows="7px" cols="25px" id="bigText"></textarea>
                    </td>
                </tr>
                <tr height="31px">
                    <td width="80px">驗證碼</td>
                    <td width="180px">
                        <input type="password" name="code" value="" id="code1" onblur="checkCoded()"/>&nbsp;&nbsp;&nbsp;
                        <span id="codeSpan" onclick="checkCode()"></span><br />
                        <span id="codeSpan2" onclick="checkCoded()"></span>
                        <!--<a href=""><span id=" rel="external nofollow" codeSpan" onclick="checkCode()"></span></a>-->  <!-- 行內(nèi)顯示一定的距離,可以直接用&nbsp;-->
                    </td>   <!--可以用a標(biāo)簽把鼠標(biāo)的圖標(biāo)變成一個小手,但是會觸發(fā)超鏈接事件,感覺不提倡-->
                </tr>
                <tr height="31px">
                    <td colspan="2" align="center">
                        <input type="checkbox" name="select" id="agree" value="1" onclick="checkAgree()" />是否同意我們的協(xié)議
                        <!--<input type="radio" name="select" id="agree" value="1" />是否同意我們的協(xié)議-->
                        <!--radio是互斥選擇,當(dāng)只有一個的時候,選中了,就取消不了了,要進行一些處理-->
                    </td>
                </tr>
                <tr height="31px">
                    <td colspan="2" align="center">
                        <input type="submit" value="注冊" id="pop" disabled="true" onclick="checkSub()"/>
                        <!--我們可不是所有的情況都可以進行submit-->
                    </td>
                </tr>
            </table>
            </div>
        </form>
    </body>
</html>

運行效果:

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運行工具http://tools.jb51.net/code/HtmlJsRun測試上述代碼運行效果。

PS:這里再為大家提供2款非常方便的正則表達式工具供大家參考使用:

JavaScript正則表達式在線測試工具:
http://tools.jb51.net/regex/javascript

正則表達式在線生成工具:
http://tools.jb51.net/regex/create_reg

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript正則表達式技巧大全》、《JavaScript表單(form)操作技巧大全》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript錯誤與調(diào)試技巧總結(jié)》及《JavaScript數(shù)學(xué)運算用法總結(jié)

希望本文所述對大家JavaScript程序設(shè)計有所幫助。

相關(guān)文章

  • 一文了解JavaScript閉包函數(shù)

    一文了解JavaScript閉包函數(shù)

    閉包是js的一個難點也是它的一個特色,是我們必須掌握的js高級特性,下面這篇文章主要給大家介紹了關(guān)于JavaScript閉包函數(shù)的相關(guān)資料,需要的朋友可以參考下
    2021-11-11
  • window.onload的頁面加載技巧

    window.onload的頁面加載技巧

    大家仔細看下面兩段代碼,代碼一的window.onload = doIt()函數(shù)后面有();而代碼二的window.onload = doIt函數(shù)名后面沒有括號。
    2008-09-09
  • JS鏈?zhǔn)秸{(diào)用的實現(xiàn)方法

    JS鏈?zhǔn)秸{(diào)用的實現(xiàn)方法

    程序開發(fā)人員可以使用一些簡單的技術(shù)來改進自己的代碼編寫工作。你可以寫一些函數(shù)來處理各種常見任務(wù),以節(jié)省時間;也可以改進一下代碼的實現(xiàn)方式,比如你可以把方法的鏈?zhǔn)秸{(diào)用技術(shù)用到自己所寫的JS庫中,把自己喜歡的方法串起來調(diào)用。
    2013-03-03
  • Javascript 模式實例 中介者模式

    Javascript 模式實例 中介者模式

    頁面上,用戶會有很多的操作 ,每進行一次操作我們需要去展示操作的結(jié)果,在這里我們有了一個問題,我們應(yīng)如何去展示不同的結(jié)果呢?
    2010-04-04
  • 用JavaScript實現(xiàn)簡單網(wǎng)頁時鐘

    用JavaScript實現(xiàn)簡單網(wǎng)頁時鐘

    這篇文章主要為大家詳細介紹了用JavaScript實現(xiàn)簡單網(wǎng)頁時鐘,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • 詳解JS獲取HTML DOM元素的8種方法

    詳解JS獲取HTML DOM元素的8種方法

    本篇文章主要介紹了詳解JS獲取HTML DOM元素的8種方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • JS中類的靜態(tài)方法,靜態(tài)變量,實例方法,實例變量區(qū)別與用法實例分析

    JS中類的靜態(tài)方法,靜態(tài)變量,實例方法,實例變量區(qū)別與用法實例分析

    這篇文章主要介紹了JS中類的靜態(tài)方法,靜態(tài)變量,實例方法,實例變量區(qū)別與用法,結(jié)合實例形式詳細分析了JS中類的靜態(tài)方法,靜態(tài)變量,實例方法,實例變量相關(guān)功能、使用方法及操作注意事項,需要的朋友可以參考下
    2020-03-03
  • 在點擊div中的p時,如何阻止事件冒泡

    在點擊div中的p時,如何阻止事件冒泡

    本文主要介紹了在點擊div中的p時,如何阻止事件冒泡的方法,具有很好的參考價值,下面跟著小編一起來看下吧
    2017-02-02
  • JavaScript內(nèi)存管理介紹

    JavaScript內(nèi)存管理介紹

    這篇文章主要介紹了JavaScript內(nèi)存管理介紹,本文講解了內(nèi)存生命周期、JavaScript的內(nèi)存分配、通過函數(shù)調(diào)用的內(nèi)存分配、當(dāng)內(nèi)存不再需要使用時釋放等內(nèi)容,需要的朋友可以參考下
    2015-03-03
  • 函數(shù)式編程入門實踐(一)

    函數(shù)式編程入門實踐(一)

    這篇文章主要介紹了Javascript函數(shù)式編程,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04

最新評論