submitボタン毎にチェックするには?
あのんきい
1999/11/11(木) 18:25:38
フォームに入力された内容を「submitボタン押下時」に
JavaScriptでチェックしています
一つのフォーム(<FORM>~</FORM>)内に一つのsubmitボタンしかない場合は
<FORM name="xxx" onSubmit="return (check(this));">
の様に、<FORM>タグ内からチェック用の関数を呼んでいます。
この関数の戻り値がtrueだったらそのまま送信され、falseだったら
送信されません
ここまでは良かったのですが…
「一つのフォーム内に複数のsubmitボタンがある場合、
submitボタンA押下時には、チェック用の関数を呼びたいが
submitボタンB押下時には、チェック用の関数を呼びたくない
というように処理を分けたい…」
以上のような処理ができずに困っています
試した方法は
1. 一つの場合と同様に<FORM>タグ内に、onSubmit~を記述する
この場合A・Bどちらのボタンを押したときでも関数が呼ばれてしまう
→ 押されたボタンをJavaScriptで区別できる方法はないでしょうか?
2. submitボタンの方から関数を呼ぶ(onClickで…。onSubmitは駄目なようです)
この場合、戻り値がfalseであっても送信されてしまう
→ 戻り値によって送信/非送信の処理を分けることはできないでしょうか?
どなたか良い方法をご存じでしたら、よろしくお願い致します(._.)
Nobu3
[E-Mail]
[HomePage]
1999/11/11(木) 19:00:21
IE4,NN4(共にWin95)では、以下のような記述では大丈夫でしたけど・・・。
キャンセルするとちゃんとキャンセルされました。
<form action="hoge.cgi">
(ここには<input>がいっぱい)
<input type=submit value="no ask">
<input type=submit value="ask" onclick="return confirm('submit?')">
</form>
あのんきい
1999/11/11(木) 19:22:52
Nobu3さんありがとうございます
確かにreturn confirm('submit?')とした場合は、うまくいくのですが
confirmではなくて、自分で作成した関数を呼び
その戻り値(true/false)によって送信/非送信と処理を分けたいのです…
例えば、
<input type=submit value="ask" onclick="return check(document.MainForm)">
とした場合に送信/非送信を分けたい
ということです
(この場合、戻り値が何であれ送信されない!!)
ちなみに現在使用しているブラウザはIE5.0およびNC4.04です
Nobu3
1999/11/11(木) 19:36:24
あれ?そうですか?
function yesno(obj){
if(confirm('submit?')){
return true;
}else{
return false;
}
}
function yesno2(obj){
if(obj.elements[0].value==''){
return true;
}else{
return false;
}
}
こんなスクリプト二つで試してみましたが、結果は同じでした。何故でしょう?
IE4.01 NN4.04です。
呼出しは以下のようなものです。
<input type=submit value="no ask">
<input type=submit value="ask" onclick="return yesno2(this.form)">
Nobu3
1999/11/11(木) 20:08:40
[[解決]]
チェックをしている関数の中にバグがあるのではと思い、
よく確認したらバグがありました
(エラーではないようですが、意図しないところに";"が記述されていました)
そのバグのために、「return (true);」の処理が実行されなかったようです
Nobu3さん、どうもありがとうございました
あのんきい
1999/11/11(木) 20:09:37
済みません、前の発言の名前が「Nobu3」さんになっていますが
私の発言です