コードに直接移動します:
<div id="register"> <h4>会员注册</h4> <div class="formdiv"> <form method="post" action="register.php?action=register" name="register" id="registerForm"> <dl> <dt>请认真填写以下内容</dt> <dd class="hasspan"> 用户名:<input type="text" name="username"> </dd> <dd class="hasspan"> 密码:<input type="password" name="pwd"> </dd> <dd class="hasspan"> 确认密码:<input type="password" name="pwdagain"> </dd> <dd id="tximg"> <img src="img/face/m01.gif" alt="选择头像" id="faceimg"> <input type="hidden" name="touxiang" value=""> <label id="imgsrclabel">m01.gif</label> </dd> <dd style="margin-right:120px;"> 验证码:<input type="text" name="code"> <span> <img src="code.php" alt="code" id="code" name="code"> <a href="#code" id="change">换一张</a> </span> </dd> <dd class="btns"> <input type="button" name="submit" id="submit" value="注册"> <input type="button" name="quit" id="quit" value="退出"> </dd> </dl> </form> </div> </div> 表单数据提交到本页面,下面是js处理 /*注册表单提交*/ function formDeal() { var btnSubmit = document.getElementById('submit'); var formId = document.getElementById('registerForm'); btnSubmit.onclick = function() { //表单的submit()方法不能提交表单 formId.submit(); } } 如果表单提交,在本页面有一段提示信息 if(!empty($_GET['action']) && $_GET['action'] == 'register') { echo '你提交了数据'; exit(); }
長い間テストした結果、プロンプトメッセージは表示されませんでした。コードが間違っているか、メソッドの記述が間違っているのではないかと思い、公式の結果ドキュメントを確認しました。エラーはありません。
formId.submit() を送信できないため、btnSubmit のタイプを submit に変更する必要があります
this.type="送信"
ネットで情報を確認すると、その理由は次の 2 点に集約されます。
1. フォームにタグ name="submit" を含めることはできません
2. フォームに「enctype="multipart/form-data"」を含めることはできません
テストした結果、これら 2 つの点はばかげており、私の問題は解決されません (おそらく問題の環境が異なるでしょう)
その後、フォーラムの友人が、送信する代わりに登録ボタンの ID を新しい名前に変更することを提案したと思いました。修正後、フォームは正常に送信され、プロンプト メッセージが表示されます。
最終要約: 送信するボタンの ID を設定しないでください。設定しないと、混乱が生じ、フォームの submit() メソッドがフォームの送信に失敗する可能性があります。 ID に名前を付けるときは、不要な煩わしさを避けるために、既存の API と名前を重複させないことをお勧めします。