ホームページ >ウェブフロントエンド >jsチュートリアル >form.submit()がform_javascriptスキルを送信できない場合のエラーの原因と解決策

form.submit()がform_javascriptスキルを送信できない場合のエラーの原因と解決策

WBOY
WBOYオリジナル
2016-05-16 16:34:102038ブラウズ

コードに直接移動します:

<div id="register">

<h4>会员注册</h4>

<div class="formdiv">

<form method="post" action="register.php&#63;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 と名前を重複させないことをお勧めします。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。