まず、このページを更新せずに、キーボード応答を使用してフォーム入力が正当かどうかを確認します。
ユーザーは、onkeydown イベントと onkeyup イベントを通じて応答イベントをトリガーします。使用方法はonclickイベントと同様です。 onkeydown は、キーボードのキーが押されたときにトリガーされることを意味し、onkeyup はその逆で、キーボードのキーが押されてから離されたときにトリガーされます。
一般的に使用される 2 つの呼び出し方法:
(1) イベントをページ要素に追加します。ユーザーが情報の入力を完了して任意のキーをクリックすると、onkeydown イベントがトリガーされ、refer() 関数が呼び出されます。
このメソッドは最も単純かつ直接的なもので、次の形式になります:
<script type="text/javascript"> ... function refer(){ ... } </script> <input type="text" onkeydown="refer()"/>
(2) window.onload による読み込み。ページが読み込まれると、イベントが読み込まれます。ユーザーが情報を入力すると、文字が入力されるたびにこのイベントがトリガーされ、イベントによって呼び出される関数でユーザーの入力情報が判断されます。
window.onload = function(){ $('regname').onkeydown = function (){ name = $('regname').value; } }
onkeydown イベントを使用すると、
2 番目、登録情報の検証
一般関数、トリガーされた ID 要素オブジェクトを返します
function $(id){ return document.getElementById(id); } window.onload事件,表示当前窗口被载入时触发。function(){...}表示当前页面被载入时所要进行的操作。 window.onload = function(){ ... }
function() 関数分析
まず、ユーザーの操作を容易にするために、ユーザー名のテキスト ボックスに注目します。次に、検出される 5 つのデータの結果を表す 5 つの変数が宣言されます。検出データが修飾されている場合は、変数の値を「yes」に設定します。
$('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 の値が異なります。
$('regname').onkeyup = function (){ name = $('regname').value; //获取注册名称 cname2 = ''; if(name.match(/^[a-zA-Z_]*/) == ''){ $('namediv').innerHTML = '<font color=red>必须以字母或下划线开头</font>'; cname1 = ''; }else if(name.length <= 3){ $('namediv').innerHTML = '<font color=red>注册名称必须大于3位</font>'; cname1 = ''; }else{ $('namediv').innerHTML = '<font color=green>注册名称符合标准</font>'; cname1 = 'yes'; } chkreg(); //调用chkreg()函数,判断5个变量是否正确 }
ユーザー名テキスト ボックスがフォーカスを失ったとき、つまりユーザーが入力を完了してページ上の他の要素に移動したとき、ユーザー名が繰り返されているかどうかが検出されます。ユーザー名判定はAjax技術を利用してchkname.phpを呼び出し(このページのユーザー名検証コードは後ほど掲載します)、chkname.phpの戻り値をもとに判定結果をdivタグに表示します。
$('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="<font color=green>恭喜您,该用户名可以使用!</font>"; cname2 = 'yes'; }else if(msg == '2'){ //数据库存在该用户返回0 $('namediv').innerHTML="<font color=red>用户名被占用!</font>"; cname2 = ''; }else{ $('namediv').innerHTML="<font color=red>"+msg+"</font>"; cname2 = ''; } } } } xmlhttp.send(null); chkreg(); //检测是否激活注册按钮 } }
パスワードを確認する パスワードを確認するときは、パスワードの長さを制限するだけでなく、パスワードの強度も判断できます。
$('regpwd1').onkeyup = function(){ pwd = $('regpwd1').value; pwd2 = $('regpwd2').value; if(pwd.length < 6){ $('pwddiv1').innerHTML = '<font color=red>密码长度最少需要6位</font>'; cpwd1 = ''; }else if(pwd.length >= 6 && pwd.length < 12){ $('pwddiv1').innerHTML = '<font color=green>密码符合要求。密码强度:弱</font>'; cpwd1 = 'yes'; }else if((pwd.match(/^[0-9]*$/)!=null) || (pwd.match(/^[a-zA-Z]*$/) != null )){ $('pwddiv1').innerHTML = '<font color=green>密码符合要求。密码强度:中</font>'; cpwd1 = 'yes'; }else{ $('pwddiv1').innerHTML = '<font color=green>密码符合要求。密码强度:高</font>'; cpwd1 = 'yes'; } if(pwd2 != '' && pwd != pwd2){ $('pwddiv2').innerHTML = '<font color=red>两次密码不一致!</font>'; cpwd2 = ''; }else if(pwd2 != '' && pwd == pwd2){ $('pwddiv2').innerHTML = '<font color=green>密码输入正确</font>'; cpwd2 = 'yes'; } chkreg(); }
2回目のパスワード判定は比較的簡単で、2回目のパスワード入力が1回目の入力と等しいかどうかを判定するだけです。
$('regpwd2').onkeyup = function(){ pwd1 = $('regpwd1').value; pwd2 = $('regpwd2').value; if(pwd1 != pwd2){ $('pwddiv2').innerHTML = '<font color=red>两次密码不一致!</font>'; cpwd2 = ''; }else{ $('pwddiv2').innerHTML = '<font color=green>密码输入正确</font>'; cpwd2 = 'yes'; } chkreg(); }
上記の情報を入力する必要があります。さらに詳細な情報を入力したい場合は、「詳細ボタン」をクリックしてください
$('morebtn').onclick = function(){ if($('morediv').style.display == ''){ $('morediv').style.display = 'none'; }else{ $('morediv').style.display = ''; } }
メール形式の確認、入力文字列には@と.が含まれている必要があります。 2 つの文字を同時に使用する 文字列の位置を先頭や末尾にしたり、連結したりすることはできません
$('email').onkeyup = function(){ emailreg = /^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/; $('email').value.match(emailreg); if($('email').value.match(emailreg) == null){ $('emaildiv').innerHTML = '<font color=red>错误的email格式</font>'; cemail = ''; }else{ $('emaildiv').innerHTML = '<font color=green>输入正确</font>'; cemail = 'yes'; } chkreg();
3、ユーザー名 (chkname.php) を検出します
<?php session_start(); include_once "conn/conn.php"; $reback = '0'; $sql = "select * from tb_member where name='".$_GET['name']."'"; $num = $conne->getRowsNum($sql); if($num == 1){ $reback = '2'; }else if($num == 0){ $reback = '1'; }else{ $reback = $conne->msg_error(); } echo $reback; ?>
4、XMLHttpRequest 関数を初期化します
// 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によるフォーム検証についてさらに詳しく解説 関連記事はPHP中国語サイトに注目!