質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

解決済

4回答

4890閲覧

FormのGET送信のURLを制御したい

ssk

総合スコア332

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

1クリップ

投稿2017/06/01 07:23

###実現したいこと
GETメソッドで、Formから検索条件を選択してsubmitを押すと未選択のnameも拾っています。

例)http://hoge.com/test?aaa=&bbb=&CCC=テスト

3つ4つくらいなら見栄えに問題はないのですが20個以上の選択項目になると、
URLがかなり長くなってしまうので、どうにか制御できないでしょうか?

例)CCCのみFormで入力or選択した場合
http://hoge.com/test?CCC=テスト

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答4

0

javascriptで値が設定されていないものをdisabledにする手はありますが
あまりいい方法とは言えません。
気にせずに空のデータを送ってやればいいと思います

sample

一応サンプルつけときます
セレクトボックスやラジオボタンを使う場合はもう少し工夫が必要です

javascript

1<script> 2function mySubmit(f){ 3 var url=f.action; 4 for(var i=0;i<f.length;i++){ 5 if(f[i].name!=="" && f[i].value!==""){ 6 url+=(url.indexOf("?")==-1?"?":"&")+f[i].name+"="+encodeURIComponent(f[i].value); 7 } 8 } 9 console.log(url); 10 location.href=url; 11 return false; 12}; 13 14</script> 15<form action="recv.php" method="get" onsubmit="return mySubmit(this);"> 16<input type="text" name="a" value="漢字"><br> 17<input type="text" name="b" value="123"><br> 18<input type="text" name="c"><br> 19<input type="submit"><br> 20</form> 21

投稿2017/06/01 07:33

編集2017/06/01 08:38
yambejp

総合スコア114839

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ssk

2017/06/01 08:33

ありがとうございます。 URLを気にするのはナンセンスですかね、、、 もう少し調べてみます。
yambejp

2017/06/01 08:38

form要素を走査すればvalueの値をみて送らないことはできます
ssk

2017/06/01 08:47

サンプルコードまでありがとうございます。 参考に実装を進めて参ります。
guest

0

未選択という状態を送っていると思うので、単純なsubmitでは抑制は無理かと思います。
POSTにしたらどうでしょうか。
それともGETにこだわる理由があるのでしょうか?

投稿2017/06/01 07:38

ttyp03

総合スコア16998

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ssk

2017/06/01 08:31

ありがとうございます。 検索結果を他の人にもシェアできるようにしたいので、GET送信にこだわっております。
guest

0

ベストアンサー

ボタンをsubmitではなくaタグなどクリックが可能な要素にして、
onclickイベントでform.submitというのはいかがでしょうか。

追記

submitボタンにnameを設定しないと送らないようです。
(というかnameがなければどのコントロールも拾われません)
用がなければ消しても良いかもしれません。

というでひとまずbutton要素にはnameを設定しないとして、
buttonのonclickを発生して検索条件をひとなめして空や未選択のものは除いて
location.hrefで自力でつなげたQueryStringをつけて画面遷移というやり方もありです。
※URLエンコードは必要です。

投稿2017/06/01 07:35

編集2017/06/01 07:45
m.ts10806

総合スコア80850

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ssk

2017/06/01 08:32

ありがとうございます。 なるほど。 こちらのやり方で行いたいと思います。
guest

0

  1. POST にする。
  2. タグでは submit ボタンを用意せず代わりのボタンを用意し、

JavaScript で取得データを整形→submit()する。
0. .htaccess で制御する。

ですかね。

投稿2017/06/01 07:44

rok6

総合スコア241

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ssk

2017/06/01 08:33

ありがとうございます。 GET送信は変更できないので、2の方法で実装したいと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問