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

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

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

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

HTML

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

Q&A

解決済

1回答

1167閲覧

JavaScriptのテキストボックスの値をPHPに渡したい

退会済みユーザー

退会済みユーザー

総合スコア0

PHP

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

HTML

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

0グッド

1クリップ

投稿2020/08/17 16:17

前提・実現したいこと

PHPをベースにして入力フォームを作っています。

プルダウンメニューの選択肢以外の「その他」の要望も多くなりそうなので、ユーザが「その他」を選択したら、テキストボックスを出現させてそこにフリーコメントをかいてもらう仕組みにしました。
スマートフォンユーザがテキストボックスが出現したことに気づきやすいように、JavaScriptを使って「その他」を選択された場合ににゅっと表示させるようにしてみました。

ここで悩んでいるのが、JavaScriptのテキストボックスの値を、どうやってPHPに渡すかという点です。
「その他」も含めたプルダウンメニューの選択肢については、POSTを使って次ページへ送ることができていますが、JavaScriptのテキストボックスの値をどうやって最終的にPHPで受け取るか。そもそも、JavaScriptの値をPHPに渡すことが可能なのか・・・?
試行錯誤していますが前に進めない状況です。

どなたか有識者の方のお知恵を拝借できたら幸いです。
どうぞ宜しくお願い致します。

※今はまだ検証中なので、サニタイズ処理などは実装していません。
※一度、文字数制限にひっかかってしまったので、コードは最低限必要と思われる部分のみ記載しています。

イメージ説明

該当のソースコード(page1.php)

<!DOCTYPE html> <HTML> <HEAD> <TITLE>食事の希望</TITLE> <META http-equiv="Content-Type" content="text/html; charset=utf-8" /> <META name="viewport" content="width=device-width, initial-scale=1"> </HEAD> <BODY> <section id="content" class="input"> <FORM METHOD="POST" ACTION="page2.php"> <dl class="form-inner"> <dt class="form-title">食事の希望</dt> <select id='ex_food' name='food' class='select'> <option value=1 selected>選択してください</option> <option value=2 >和食</option> <option value=3 >洋食</option> <option value=4 >中華</option> <option value=5 >その他</option> </select> <!-- 「その他」が選択されたらテキストボックスを表示させる--> <div id="ex_food_box_div" style="display:none;"> <input id="ex_food_box" type="text" /> </div> <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script> <script> document.getElementById("ex_food").addEventListener("change", function(){ var equipment_type_elem = document.getElementById("ex_food"); var s_value = food_elem.options[food_elem.selectedIndex].value; if(s_value == 5){ $("#ex_food_box_div").show("normal"); }else{ $("#ex_food_box_div").hide("normal"); } }, false); </script> <INPUT TYPE="submit" class="btn btn-square" VALUE="確認"> <button type="button" class="btn btn-back" onclick="history.back()">戻る</button>  </FORM> </section> </BODY> </HTML>

試してみたこと

document.getElementById("ex_food_box").value;
などのようにしてテキスト入力値を取得してから、どうにかしてPHPに渡せないものかと思うのですが・・・この先がわかりません。
(このページ内でPHPに渡せるのか、次のページでPHPで受け取るのか、方法は問いません)

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

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

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

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

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

guest

回答1

0

ベストアンサー

page1.php内の<input id="ex_food_box" type="text" />にname属性を追加して
page2.php側で受け取れませんか?

page1.php

<input id="ex_food_box" name="hoge" type="text" />

page2.php

$hoge = $_POST['hoge'];

投稿2020/08/17 17:31

kajimaru315

総合スコア22

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

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

退会済みユーザー

退会済みユーザー

2020/08/17 23:28

ご助言ありがとうございました。ご指摘の方法で解決(page2.phpで受け取る)しました。妙に難しく考え、基本を見落としていました。この度は本当にありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問