HTML5+CSS3でゲームを作っています。
フォームがあり、ボタンが複数並んでいます。
<SCRIPT TYPE="text/javascript">
<!--
function sendform(){
submitForm();
}
function submitForm(){
document.form1.submit();
}
// -->
</SCRIPT>
<FORM action="buy.cgi" method="post" name="form1" id="form1">
<button class="button8" type="submit" name="d4_buy" value="300 onclick="sendform()">300購入</button>
<button class="button8" type="submit" name="d4_buy" value="400" onClick="sendform()">400購入</button>
</FORM>
上記で正常に作動しますが、3G環境など通信状態の悪い時に、「300購入ボタンを押した直後に400購入ボタンを押す」と700購入が出来てしまいます。
【希望事項】
2つのボタンを連続して押しても2つ目が無効になるようにしたいというのが希望です。
ネットで調べたところ
******************************************
http://oshiete.goo.ne.jp/qa/627484.html
******************************************
<HTML><BODY>
<FORM method="get" action="http://www.google.com/search">
<INPUT type="submit" value="submit1" onclick="this.form.q.value=this.value;this.disabled=true;this.form.submit()">
<INPUT type="submit" value="submit2" onclick="this.form.q.value=this.value;this.disabled=true;this.form.submit()">
<INPUT type="hidden" name="q" value="" >
</FORM></BODY></HTML>
******************************************
という例があったため、この例に従って
<SCRIPT TYPE="text/javascript">
<!--
function sendform(){
submitForm();
}
function submitForm(){
document.form1.submit();
}
// -->
</SCRIPT>
<FORM action="buy.cgi" method="post" name="form1" id="form1">
<button class="button8" type="submit" value="300 onclick="this.form.q.value=this.value;this.disabled=true;this.form.sendform()">300購入</button>
<button class="button8" type="submit" value="400" onclick="this.form.q.value=this.value;this.disabled=true;this.form.sendform()">400購入</button>
<INPUT type="hidden" name="d4_buy" value="" >
</FORM>
としてみたのですが、うまく数値の引き渡しが出来ません。(NULL となります)
どのように改造すればいいか教えてください。
よろしくお願いいたします。
A 回答 (4件)
- 最新から表示
- 回答順に表示
No.3
- 回答日時:
転記ミスでなければ
this.form.q.value → this.form.d4_buy.value
(2箇所とも)
※余談ですがFromに内包できるSubmitはひとつだけだったはずです
この回答への補足
有難うございます。
ご指摘の方法で対応してみましたがダメでした。
<INPUT type="hidden" name="d4_buy" value="" >
のvalue="" が優先されてしまうのかNULL=エラーになってしまいました。
難しいです.....
No.1
- 回答日時:
この回答への補足
有難うございます。
「1つのボタンの2度押し防止」であればURLのやり方でいいのですが、今回必要なのは複数のボタンに対して制御を掛けるものです。
URLの方式では、300ボタンの2度押しの制御は出来ても、300の次に400を押すという連続作業には無防備です。
よろしくお願いいたします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- JavaScript 入力フォームの javascript で メールアドレスの正規チェックをを行い、ボタンをクリックして 2 2022/04/27 16:06
- HTML・CSS ボタンをクリックした時に、入力フォームのすぐ下部に、「入力欄が空白です」というテキストメッセージが表 1 2022/04/27 16:25
- JavaScript ①入力フォーム→②確認表示画面→③送信完了画面のコードを書いているのです、 入力フォームから受け取っ 2 2022/05/10 16:45
- JavaScript javascriptのちょっとした動作不良(原因は突き止めたのですが) 1 2023/06/15 19:58
- JavaScript javascriptで移動ボタンを押した際に遷移するボタンを追記したい 1 2022/11/29 03:02
- JavaScript 1日1回引けるJavaScriptおみくじについて 1 2022/12/12 22:28
- JavaScript sessionStorageを調べています。 1 2023/06/20 12:41
- JavaScript フォームが空欄の時にフォームの外をクリックすると、エラーが出るコードを調べています。 1 2023/06/25 11:51
- JavaScript javascript作成してます。ラジオボタンで判定するコードを書いてます。 1 2023/07/18 11:03
- JavaScript jqueryを使ったスムーススクロールのコードを書いたのですが、HTMLコード内にある、a butt 2 2022/04/14 10:59
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ボタン2回押しを無効にしたい
-
メッセージボックスで「はい」...
-
Javascriptで二重送信を防止し...
-
<form action="#">の意味とは?
-
フォーム内で記入したクエリ送...
-
トグルボタンの文字色
-
イントラマート
-
confirmのOK・キャンセルを押し...
-
onclickイベントでの二重送信防...
-
return trueとreturn falseの用...
-
プルダウン 項目が多いので先頭...
-
hiddenのvalueの値を変えたい
-
onchangeイベントを強制的に発...
-
チェックボックスの設定
-
javascriptでASPにデータを渡す
-
テキストエリアをenterキーでフ...
-
クリックの度に加算していくには?
-
プルダウンで選択すると、DBの...
-
【jQuery】input nameの文字列...
-
フォームで入力した値を別のフ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBSでブラウザ上のテキストボッ...
-
submitするとなぜか2度実行する
-
onclickで2個指定するには?
-
confirmのOK・キャンセルを押し...
-
ボタン2回押しを無効にしたい
-
フォーム内で記入したクエリ送...
-
onClick="this.form.submit
-
JavaScriptにおいてPOSTで送信...
-
disabled プロパティが表示され...
-
確認ダイアログの出し方(JavaS...
-
onclickをEnterキーでも行いたい
-
jsで質問です。 ボタンが二つ存...
-
ボタン無しでフォーム内容送信
-
confirm()で表示したダイアログ...
-
ボタンを押すとチェックボック...
-
javascriptで二重送信防止
-
VBScript
-
メールフォーム:「必須項目」...
-
Javascriptで二重送信を防止し...
-
ホームページビルダーでメール...
おすすめ情報