複数のinputを送信時に値をフォーマットに従ってまとめて送信するとき
そのもととなった複数のinputは送信しないようにしたいです
(郵便番号など入力欄を二つにわけるが送信時は一つにまとめるなど)
nameを付けないという方法も考えましたが
radioを含む場合に不都合なのでこの方法はとりたくありません
また送信時にinputを削除するという方法も
ajaxで元のページにとどまることも考えうるので
この方法もとりたくありません
理想はinputに特定の属性値を与えると
form送信時に送信しないようになる
とかだったのですがその方法は見つけられませんでした
クライアントサイドでの処理が難しそうなら
サーバーサイドでの処理にしますが
できれば避けたいと思っています
よろしくお願いします
No.4ベストアンサー
- 回答日時:
できないです。
そもそもCGI側に渡すための物ですから
(郵便番号など入力欄を二つにわけるが送信時は一つにまとめるなど)
入力ページから送信された物は一旦CGI側で、
$postcode="120-1135";
とかになって、
<input type="hiidden" name="zip-code" value="120-1135">
・・・・・
<th>郵便番号</th><td class="zip-code">120-1135</td>
とtableか、
<input type="text" name="zip-a" value="120" readonly>-<input type="text" name="zip-b" value="1135" readonly>
とかの再フォーになっているはず。
<input type="text" name="zip-a" value="120">-<input type="text" name="zip-b" value="1135">
で修正を受け付けても良い。
>クライアントサイドでの処理が難しそうならサーバーサイドでの処理にしますができれば避けたいと思っています
これ、根本的に間違っています。
javascriptなどはユーザー側に制約されるので、可能な限り楽な方法--CGI側で処理すべきです。そのほうが楽です。
回答ありがとうございます
よくよく考えると入力されDBに保存された値から
逆算してフォームに自動入力しなきゃいけないことなどもあって
入力値とフォームの値が一致しないのは不都合の方が多く
DBには複数のフォームの入力値は
そのまま別々に保存して出力等の処理で合成処理をする形を
とるようにするのが一番良いと結論しました
今回の用途としてはCMSの投稿記事のタイトルを
必ず特定のフォーマットで入力させたいというもので
DBにパーツ毎に別々に置いておくということはできないものだったのですが
タイトルを特定のフォーマットに従わせることには汎用性があると判断し
タイトルの元になる複数の情報を別個にDBに置き
投稿時、編集時にその値を利用してタイトルを生成して
DBの記事タイトルとして保存するという処理を
共通処理に追加することにしました
No.3
- 回答日時:
そもそもサーバー側の正しいあり方として
「関係のないデータは無視する」のはずなので、
無関係なデータを送信しても、なんの問題もないとは思うのですが。
サーバー側で何とかするならば
処理に関係ない入力欄の name を notdata_ で始まる命名とする
サーバー側で notdata_ で始まる引数は処理しない汎用ルールを追加
例) 郵便区番号: notdata_postalcode3
クライアント側で何とかするならば
// フォームをDOM上で生成して値を設定して送信して即廃棄する方法
// 通常通り画面遷移して、元のフォームも汚さない
元のフォーム.addEventListener('submit', function(event){
var data = フォームの値を読み取る(元のフォーム);
var form = document.createElement('form');
form.action = 元のフォーム.action;
form.method = 元のフォーム.method;
for (var name in data) {
var hidn = form.appendChild(document.createElement('input'));
hidn.type = 'hidden';
hidn.name = name;
hidn.value = data[name]; // TODO:複数選択可能なリスト入力に対応
}
form.submit();
}, false);
回答ありがとうございます
サーバー側は配列で渡された入力値を
foreachで回してキー値によって処理を変える
というような処理をしているため
要らないデータがあると処理に支障を
来たす可能性があるため避けたかったのです
しかし結論としてはNo.4様に述べた様にしたため
そもそもこういうことはしなくていいことになりました
ありがとうございました
No.2
- 回答日時:
特定のformをsubmitする際に、処理を奪って
別のformを強制でつくり必要なデータを移したうえでそのformをsubmitする
・・・とか、やりようはありますが、結局disabledを利用するのと
たいして変わりません。
おそらく命題自体に無理があるので「できない」というのが回答でしょう
No.1
- 回答日時:
>クライアントサイドでの処理が難しそうなら
>サーバーサイドでの処理にしますが
>できれば避けたいと思っています
難しくはないですが、結局クライアントで処理したものは
サーバー側でチェックするのでサーバーサイドの処理は必須ですよ
送りたくないだけであればsubmitするときに該当するinputにdisabledを
つけてやればいいでしょう。
ただしブラウザの戻るボタン対策を考えるとonload時にdisabledをクリア
してやる必要があるかもしれません
いずれにしても本質的には解決しませんし、この手の処理はやらない方がいいと思います
この回答への補足
サーバサイドで処理するのを避けたいのは
送る先のプログラムが様々なところで
共通で使うものなので
イレギュラーな処理をなるべく
入れたくないという理由です
様々な場所で共通で使うプログラムに入れるほど
このイレギュラー処理が汎用性があるのか
という疑問ゆえにクライアントサイドで
処理するのが望ましいと考えいています
回答ありがとうございます
jqueryMobile上のフォームで
ajaxで送信することにもなるので
やはり提案いただいた方法も
要素を削除するのと同様、避けたい方法です
申し訳ありません
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
tableタグとformタグの組み合わせ
HTML・CSS
-
Javascript_submit()完了後に処理したい
JavaScript
-
<a href=#" …>の意味を教えてください。"
HTML・CSS
-
-
4
POST時に要素を削除してからPOST
JavaScript
-
5
ダブルクォーテーションのreplaceの方法
JavaScript
-
6
別formのhidden項目を自form値として送信したい
Perl
-
7
テーブルタグの中にdivを含めてはダメ?
HTML・CSS
-
8
GROUP BYを使ったSELECT文の総件数を求める方法
SQL Server
-
9
name属性のないformタグの、中身を操作する方法を教えてください
JavaScript
-
10
SQLで、Join句で結合したテーブルにデータが無い場合について
SQL Server
-
11
onchangeイベントを強制的に発生させる
JavaScript
-
12
フォームで同じ複数のnameで違うvalueの送信
Java
-
13
PHPのif文でその処理を途中で抜けるにはどうすればよいでしょうか?
PHP
-
14
【jQuery】input nameの文字列を変数を使い動的にする方法
JavaScript
-
15
<input type=hidden" >で配列(複数の要素)を渡したいとき?"
PHP
-
16
PageLoadの後にJavascript実行したい
Microsoft ASP
-
17
テキストエリア内の改行禁止
HTML・CSS
-
18
submitボタン押下時にPOSTされるデータを追加
JavaScript
-
19
jspからjavascriptの変数引継ぎ
JavaScript
-
20
JavaScriptで変更した属性の元の値の取得
JavaScript
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
テキスト入力後、エンターを押...
-
formで特定のinputを送信しない...
-
JSONで文字列が長い時
-
Application.ScreenUpdating = ...
-
FindFirst を複数条件で検索
-
文字の横にプルダウンを表示さ...
-
sendmailで複数アドレスに送信...
-
前日の日付取得するには?
-
ACCESS テキストボックスを隙...
-
[python] 文字列を変数名として...
-
メモリをアドレスを直接指定し...
-
メ-ルにno problem@の前にname...
-
VB6で、長い時間かかる処理...
-
実行中の変数の中身をイミディ...
-
【至急!!!】python言語で本を見...
-
セレクトメニューで2つの項目...
-
セレクトメニューで選んだ値を...
-
実行時エラー 3020の対策
-
CGIのテキストが文字化けし...
-
16進の10進変換について
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
formで特定のinputを送信しない...
-
子windowsからsubmit()後にclos...
-
ホームページビルダーのメール...
-
display: none をすると Enter ...
-
cgiへのパラメータについて
-
javascriptでCGIを実行するには
-
変数の内容が表示できません。p...
-
メール送信フォームつきのポッ...
-
POSTとサイズ指定
-
if文を入れるとcgiが動きません...
-
Application.ScreenUpdating = ...
-
JSONで文字列が長い時
-
この曲のピアノの最後の和音が...
-
16進の10進変換について
-
実行時エラー 3020の対策
-
文字の横にプルダウンを表示さ...
-
FindFirst を複数条件で検索
-
<SELECT>タグの折り返し
-
VBAでPDFのコピーとリネームを...
-
pythonで演算子を変数に代入す...
おすすめ情報