JavaScript初心者です。
PHPとXHTMLでHPを作成中ですが、タイトルにあるようにHPの一部のみ更新することが可能でしょうか?
JavaScriptで不可能な場合はどの言語で出来ますか?
やりたいことはセレクトで選択したらobjectで表示中のページのみ変更する事です。
分からないなりに作ってみたサンプルの結果がこれです。
index.php
------------------------
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dt …
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja" lang="ja">
<head>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<title>サンプル</title>
</head>
<body>
<div>
<div>
<form action="aaa.php" method="post">
<select name="category" id="category" onchange="submit();">
<option value="0">A</option>
<option value="1">B</option>
<option value="2">C</option>
<option value="3">D</option>
・
・
・
<option value="25">Z</option>
</select>
</form>
<object data='test.php?category='<?=$_POST['category']?> height="50" width="200" ></object>
</div>
ここに別要素の表示<br />
出来れば更新したくない。
<div>
</div>
</body>
</html>
------------------------
test.php
------------------------
<html>
<body>
<?php
if($_POST['category']==0){
$a='AAA';
}elseif($_POST['category']==1){
$a='BBB';
}elseif($_POST['category']==2){
$a='CCC';
}elseif($_POST['category']==3){
$a='ddd';
}elseif($_POST['category']==25){
$a='ZZZ';
}
print $a.'が選択されました。';
?>
</body>
</html>
------------------------
これだとtest.phpにパラメータが送れませんし、セレクトで選択しても更新がかかって初期のAに戻ってしまいます。
かといって<form action="test.php" method="post">にするとtest.phpへ飛んでしまいます。
出来れば詳しいサンプルコードを教えていただけるとありがたいです。
No.2ベストアンサー
- 回答日時:
全部phpで処理しているなら、
別要素を表示するphpをaaa.phpとして、test.phpと同じく下のように作っておいて
<aaa.php>
------------------------
<html>
<body>
<?php
if($_GET['category']==0){
$a='aaa';
}elseif($_GET['category']==1){
$a='bbb';
}elseif($_GET['category']==2){
$a='CCC';
}elseif($_GET['category']==3){
$a='ddd';
}elseif($_GET['category']==25){
$a='ZZZ';
}
print(file_get_contents($a . ".htm"));
?>
</body>
</html>
------------------------
これを呼び出す別の<object>をindex.phpで出力すればよい
<index.php>
------------------------
<body>
<div>
<div>
<?php
$selected["category"][$_POST["category"]]=" selected";
print <<<eof1
<form method="post" action="{$_SERVER["PHP_SELF"]}">
<select name="category" id="category" onchange="this.form.submit();">
<option value="0"{$selected["category"]["0"]}>A</option>
<option value="1"{$selected["category"]["1"]}>B</option>
<option value="2"{$selected["category"]["2"]}>C</option>
<option value="3"{$selected["category"]["3"]}>D</option>
</select>
</form>
<object data="test.php?category={$_POST['category']}" height="50" width="200" ></object>
eof1;
?>
</div>
ここに別要素の表示<br />
<?php
print <<<eof2
<object data="aaa.php?category={$_POST['category']}" height="480" width="600" ></object>
eof2;
?>
</div>
</body>
------------------------
test.php
------------------------
<html>
<body>
<?php
if($_POST['category']==0){
$a='AAA';
}elseif($_POST['category']==1){
$a='BBB';
}elseif($_POST['category']==2){
$a='CCC';
}elseif($_POST['category']==3){
$a='ddd';
}elseif($_POST['category']==25){
$a='ZZZ';
}
print $a.'が選択されました。';
?>
</body>
</html>
------------------------
yyr446さん回答ありがとうございます。
質問した私が間違っていました。
<form action="aaa.php" method="post">とありますが「aaa.php」ではなく「index.php」の間違いでした。
aaa.phpで作っていてindex.phpに修正して掲載するはずがそのまま掲載してしまいました。
おバカなことしてすみませんm(_ _)m
ですが、yyr446さんの回答をヒントにaaa.phpのワンクッションを入れずにtest.phpを直接表示させることが出来ました。
ありがとうございました。
No.3
- 回答日時:
インラインフレームはダメですか?
(一部端折り&改造)
index.php
<form action="aaa.php" target="betsu" method="post">
<select name="category" id="category" onchange="submit();">
<option value="0">A</option>
<option value="1">B</option>
<option value="2">C</option>
</select>
</form>
<iframe src="about:blank" name="betsu"></iframe>
-------------
aaa.php
<html>
<body>
<?php
var $pages=['AAA','BBB','CCC'];
var $page=$pages[$_POST['category']]||'blank';
print $page.'が選択されました。';
?>
</body>
</html>
この回答への補足
回答ありがとうございます。
XHTMLの厳密形を使用すると「インラインフレームは非推奨となるのでオブジェクトで代用」という記事を見たのでインラインフレームを使用していません。
この方法はオブジェクトでは出来ないのですか?
と言ってもXHTMLの厳密形である理由は「どうせ勉強するなら今後主流になる?という記事を見たので厳密形をやろう」と言うくらいなので、特にこだわりはありません。
いまさらながらXHTMLの厳密形は良くないのでしょうか?
No.1
- 回答日時:
そういうのはajaxでやるのが妥当でしょう。
また、>セレクトで選択しても更新がかかって初期のAに戻ってしまいます。
だけが問題なら、戻らないずパラメータを引き継ぐように
<?
$selected["category"][$_POST["category"]]=" selected";
print <<<eof
<form method="post">
<select name="category" id="category" onchange="this.form.submit();">
<option value="0"{$selected["category"]["0"]}>A</option>
<option value="1"{$selected["category"]["1"]}>B</option>
<option value="2"{$selected["category"]["2"]}>C</option>
<option value="3"{$selected["category"]["3"]}>D</option>
</select>
</form>
eof;
?>
のような書き方でもよいと思います
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- JavaScript セレクトボックスを2つ設けて選択して初めてメッセを表示 1 2022/07/27 12:15
- JavaScript switch文のswitch(n)の部分を複数の値にするか、if文に変えてほしいです。 1 2022/07/27 17:18
- PHP PHPでCookieを使った訪問回数について 1 2023/05/28 14:10
- JavaScript 以前の質問だと、どの条件でも配列が表示されてしまいます。 1 2022/07/09 11:40
- JavaScript セレクトを全て選択されていないと、文字によるエラーメッセージを表示させるコードを調べています 2 2023/06/22 15:48
- PHP 入力した部分を表示させたまま(保持)するにはどうすれば良いでしょうか? 1 2023/01/25 11:14
- JavaScript sessionStorageを調べています。 1 2023/06/20 12:41
- HTML・CSS 私の能力からして間違っていないような気がします。 4 2022/09/30 13:24
- JavaScript 入力フォームの javascript で メールアドレスの正規チェックをを行い、ボタンをクリックして 2 2022/04/27 16:06
- JavaScript ①入力フォーム→②確認表示画面→③送信完了画面のコードを書いているのです、 入力フォームから受け取っ 2 2022/05/10 16:45
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・「みんな教えて! 選手権!!」開催のお知らせ
- ・漫画をレンタルでお得に読める!
- ・【選手権お題その1】これってもしかして自分だけかもしれないな…と思うあるあるを教えてください
- ・【穴埋めお題】恐竜の新説
- ・我がまちの「給食」自慢を聞かせてっ!
- ・冬の健康法を教えて!
- ・一番好きな「クリスマスソング」は?
- ・集合写真、どこに映る?
- ・自分の通っていた小学校のあるある
- ・フォントについて教えてください!
- ・【大喜利】【投稿~12/6】 西暦2100年、小学生のなりたい職業ランキング
- ・これが怖いの自分だけ?というものありますか?
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・とっておきの「夜食」教えて下さい
- ・これまでで一番「情けなかったとき」はいつですか?
- ・遅刻の「言い訳」選手権
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・10代と話して驚いたこと
- ・14歳の自分に衝撃の事実を告げてください
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
<select> をmultiple にしてい...
-
コードレビューをお願いします。
-
プルダウンの値によって活性・...
-
Selectボックスの一覧表示方法
-
selectのnameが配列の場合
-
selectを変更不可にしたい
-
JavaScriptで<select>の<option...
-
プルダウン選択を変更すると、...
-
まったく同じ<select>フォーム...
-
セレクトボックスの組み合わせ...
-
全てのselect要素をデフォルト...
-
スマホのフォームでのselect複...
-
プルダウン連動とリンク
-
3つのselectでURLパラメータを...
-
return trueとreturn falseの用...
-
プルダウン 項目が多いので先頭...
-
slickのレスポンシブ > center...
-
value内に変数を入れたい
-
【jQuery】input nameの文字列...
-
<JavaScript>tableタグを入力不...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
プルダウン選択を変更すると、...
-
<input>の選択肢をプルダウンメ...
-
javascriptでセレクトボックス...
-
VBScriptでHTMLのセレクトボッ...
-
全てのselect要素をデフォルト...
-
Selectボックスの一覧表示方法
-
selectを変更不可にしたい
-
同じ名前のセレクトがある場合...
-
スマホのフォームでのselect複...
-
<select> をmultiple にしてい...
-
selectが変更されたらnameを指...
-
select要素のvalueを配列で取得...
-
プルダウンの選択値により活性...
-
ラジオボタンの選択に応じてプ...
-
まったく同じ<select>フォーム...
-
JavaScriptで<select>の<option...
-
ラジオボタンの値が取得できな...
-
プルダウンの値によって活性・...
-
webページの一部のみの更新につ...
-
今日の日付を自動的にセレクト...
おすすめ情報