JavaScriptで1page目で指定したパラメータを2page目で別のフォーム内のtextボックスに記入する際、他にも作るテキストボックスと違う文字色にしたいのですが、方法が判りません。そもそもそんなことできないのでしょうか?
------- 1page目 -------
<html>
<head>
<title>別ページのフォームにパラメータを送る</title>
</head>
<body>
<table border="1" cellpadding="5" cellspacing="5" width="80">
<tbody><tr>
<td align="center">
<input type="button" onClick="location.href='form2.html?No.001'" value="セット"></td>
<td align="center">
<input value="閉じる" onClick="window.close()" type="button"> </td>
</tr>
</tbody>
</table>
</body>
</html>
----- 2page目 -----
<html>
<head>
<title>別ページからのパラメータをフォームに書き込む</title>
<script language="JavaScript">
<!--
function pdata()
{
para= location.search;
para = para.substr(1,6);
document.myform.number.value=para;
}
//-->
</script>
</head>
<body onLoad="pdata()">
<table border="1" cellpadding="2" cellspacing="2" width="150">
<tbody>
<form name="myform" method="post">
<TR>
<TD >番 号</TD>
<TD ><input name="number" type="text" id="番号" size="15" /></TD>
</TR>
</form>
</tbody>
</table>
</body>
</html>
No.3ベストアンサー
- 回答日時:
<html>
<body>
<form action="test1.html" method="post" onSubmit="hoge()">
<p>
<input type="text" id="a" value="abcde"><br>
<input type="text" id="b" value="aiueo"><br>
<input type="submit">
</p>
</form>
<script>
window.onload=function(){
saveCookie('a','',1); saveCookie('b','',1);
}
function hoge(){
saveCookie('a',document.getElementById('a').value,1);
saveCookie('b',document.getElementById('b').value,1);
return true;
}
function saveCookie( vn, v, dy ){ if(navigator.cookieEnabled) document.cookie=vn+'='+escape(v)+ ';expires='+new Date((new Date()).getTime()+dy*86400000).toGMTString();}
</script>
--------------
<html>
<head><style>.col1{color:#f00}</style></head>
<body>
<form submit="test1.html" onSubmit="hoge()">
<p>
<input type="text" id="a" value="abcde"><br>
<input type="text" id="b" value="aiueo"><br>
<input type="submit">
</p>
</form>
<script>
window.onload=function(){
var v;
document.getElementById('a').className=(v=loadCookie('a'))?'col1':''; document.getElementById('a').value= v;
document.getElementById('b').className=(v=loadCookie('b'))?'col1':''; document.getElementById('b').value= v;
}
function saveCookie( vn, v, dy ){ if(navigator.cookieEnabled) document.cookie=vn+'='+escape(v)+ ';expires='+new Date((new Date()).getTime()+dy*86400000).toGMTString();}
function loadCookie(vn){ var r = '',o = document.cookie.split('; '); for (var i in o){ var c = o[i].split('='); if (c[0]==vn && c[1]!=''){ r = c[1]?unescape(c[1]):'';break; }} return r;}
</script>
_pipi_さん
回答有難うございました。
難しいスクリププトをいただきました。これから解読させていただきます。とりあえずお礼まで。
No.4
- 回答日時:
受け渡しにはクッキーを使ってます
saveCookie(vn,v,dy)のvnは変数の名前、vは変数の値、dyが保存期間
loadCokkie(vn)で変数の名前の値を読み出します
もし渡されたデータがnull以外だったら赤色に変える
if(para=='') document.getElementById('a').style.color='#f00';
サンプルは、データの受け渡しがあれば、スタイルシートで
classNameをcol1(赤)にしてます。
あと自分のミス発見
2つめのHTMLでフォームの
<form submit="test1.html" onSubmit="hoge()">
のsubmit="test1.html"は意味がありません
なくして、idでもふってください
_pipi_さん
No.4の補足説明有難うございました。クッキーでお受け渡し方法参考になりました。有効期限付きでの受け渡し方法までできることがわかり大変参考になりました。
渡されたデータの内容で色変えをする条件文なども大凡理解できました。もう少し自分の中で、理解を深め自分の応用例に組み込んで見たいと思っています。有難うございました。
フォーム内で、単純に特定のテキスト欄などの文字フォント、色、背景色などはstyleでHTMLでも処理できるのでそちらの方法とも組み合わせて行こうと考えています。
No.2
- 回答日時:
javascirptでパラメータの受け渡しをするのであれば、
(1)getでlocation.searchをつかう
(2)hash値をつかう
(3)クッキーをつかう
などあると思いますが、どれも中途半端。
やはりデータの受け渡しにはgetやpostをつかったサーバーサイドの
プログラムを利用するのが賢明です
yambejpさん、
回答にお礼を申し上げます。
質問にも書かせていただきましたが、パラメータの引渡しについては、URL上に丸見えになりますが、この方法で引き渡すことで問題意識は持っていません。これでOKと思っています。質問のポイントはこの引き渡された「?=no.001」から「no.001」を抽出してフォームのテキスト内に指定した色で書き込む方法が考えつかなくてお知恵を駆りたくて質問したのです。例示したスクリプトで黒色であればテキスト欄内に「no.001」は書き込まれているかと思います。この色を黒でなく指定した色にしたいのです。他のテキスト欄は黒色でよく、パラメータとして引き渡されたものだけを識別できるように色を変えたいのです。お分かりいただけますでしょうか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- AJAX JavascriptからPHPへのAjax通信でnullが返ってくる 3 2022/08/03 22:00
- JavaScript 入力フォームの javascript で メールアドレスの正規チェックをを行い、ボタンをクリックして 2 2022/04/27 16:06
- HTML・CSS ボタンをクリックした時に、入力フォームのすぐ下部に、「入力欄が空白です」というテキストメッセージが表 1 2022/04/27 16:25
- JavaScript HTMLでJavaScriptを使ってパスワードの強化判定のプログラムを作成しています。 一通り作っ 2 2022/10/19 01:41
- JavaScript javascriptのちょっとした動作不良(原因は突き止めたのですが) 1 2023/06/15 19:58
- HTML・CSS 私の能力からして間違っていないような気がします。 4 2022/09/30 13:24
- JavaScript jqueryを使ったスムーススクロールのコードを書いたのですが、HTMLコード内にある、a butt 2 2022/04/14 10:59
- PHP php ログイン 1 2022/11/01 00:24
- JavaScript ①入力フォーム→②確認表示画面→③送信完了画面のコードを書いているのです、 入力フォームから受け取っ 2 2022/05/10 16:45
- PHP PHP MySql 画像を取得 1 2022/06/04 14:05
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
TextBoxに半角数字以外を入れた...
-
どちらかひとつのテキストボッ...
-
JSで一つのボタンを押したとき...
-
フォーカスが外れたときの動作...
-
マイナスなら赤字で表示したい...
-
VBscriptの配列変数をJavascrip...
-
HTMLファイル同士での値渡し
-
jQueryのdatepickerの日付が選...
-
テキストエリアに履歴を残したい
-
プルダウン選択を変更すると、...
-
onchangeイベントを強制的に発...
-
select要素のvalueを配列で取得...
-
度胸試しのJavaScript
-
動的なセレクトボックスの生成...
-
プルダウン 項目が多いので先頭...
-
return trueとreturn falseの用...
-
<JavaScript>tableタグを入力不...
-
メールフォーム:「必須項目」...
-
画面表示とともにtableの指定の...
-
正規表現で複数マッチ条件で悩...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
HTMLとJavaScriptで作った表示...
-
GetElementByIdがうまく取得で...
-
tabindexの取得
-
TextBoxに半角数字以外を入れた...
-
JavaScriptで作ったアプリが正...
-
プルダウンで選択された値を別...
-
HTMLファイル同士での値渡し
-
フォームの内容でリンク先URLの...
-
ページ間で変数を保持したい
-
テキストボックスに初期値で1...
-
javascriptのちょっとした動作...
-
入力するテキストエリアをボタ...
-
jQueryのdatepickerの日付が選...
-
JSPでonChangeを強制発行するに...
-
マイナスなら赤字で表示したい...
-
大文字か小文字かを判断する方法
-
VBscriptの配列変数をJavascrip...
-
一部Enter無効化の方法を教えて...
-
テキストエリアに履歴を残したい
-
フォーカスが外れた時の入力チ...
おすすめ情報