
いつもお世話になります。
javascriptにて、ページを開くと、
セレクトボックスの値が、初期値になるようにしようと思ってますがうまくいきません。
詳しく書きますと、担当者一覧がセレクトボックスに入っていて、
そのページを開くと、ログインしている担当者名が選ばれた状態にしたいのです。
※たとえば、「山本太郎」でログインしているとすると、ページを開くとセレクトボックスが、
「山本太郎」が選ばれている状態にしたいのです。
いろいろ調べて、自分なりにソースを書いてみましたが、うまくいきません。
以下ソースになります。
<SCRIPT LANGUAGE="JavaScript" >
var tantou = "<%=Rs("作業担当者")%>"
var element = document.getElementById("sagyounm");
for (var i=0; i<element.options.length;i++) {
if(element.options[i] === 'tantou'){
element.options[i].selected = true;
break;
};
};
</SCRIPT>
Rs("作業担当者")は、ログインした担当者名です。
たぶん上記のソースはセレクトが選ばれている値を取得してるだけだと思います。
***********************************************
以下は、セレクト部分です。
<select name="sagyoutantou" id="sagyounm" required>
<option value=""/>---作業担当者選択---</option>
<option value="山本 太郎"/>山本 太郎</option>
<option value="山下 清"/>山下 清</option>
<option value="岡本 次郎"/>岡本 次郎</option>
どうにか、初期状態から担当者が選ばれている状態にできないでしょうか。
お忙しいとは思いますが、
おわかりの方いらっしゃいましたら、
どうかご教授お願いします。
No.1ベストアンサー
- 回答日時:
3点修正が必要
(1)load後の処理になるのでwindow.onloadで処理する
(2)element.options[i]ではなくelement.options[i].value
(3) 'tantou'ではなくtantou
ざっと、こんな感じ
<script>
window.onload=function(){
var tantou = "山本 太郎";
var element = document.getElementById("sagyounm");
for (var i=0; i<element.options.length;i++) {
if(element.options[i].value === tantou){
element.options[i].selected = true;
break;
};
};
}
</script>
<select name="sagyoutantou" id="sagyounm" required>
<option value=""/>---作業担当者選択---</option>
<option value="山本 太郎"/>山本 太郎</option>
<option value="山下 清"/>山下 清</option>
<option value="岡本 次郎"/>岡本 次郎</option>
No.2
- 回答日時:
よくわかりませんが…
>if(element.options[i] === 'tantou'){ ~~
だと'tanntou'という文字列と比較してしまっているので、多分、一致することはないでしょう。
変数tanntouの内容と比較するのでしょうから、
if(element.options[i] === tantou){ ~~
とすればうまくいくかも…
あと、質問文からはわかりませんが、DOM構築後にスクリプトを実行するようになっていますよね?
ところで、
>var tantou = "<%=Rs("作業担当者")%>"
って、サーバーサイドで処理しているのでしょうから、わざわざクライアントサイドで選択する処理をしなくても、出力するときに担当者をselectedにしておくとか、あるいはセレクトタグなどでなく担当者は固定にしてしまうとかでもよさそうに思いますが…
回答ありがとうございました。
まだまだ初心者なので、「''」をつけるのかどうかわかっておりませんでした。
サーバーサイドとクライアントの処理がまだよくわかってませんので、中々難しいです。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
selectが変更されたらnameを指...
-
プルダウン選択を変更すると、...
-
ラジオボタンとプルダウンを連...
-
selectを変更不可にしたい
-
selectボックスの選択結果を変...
-
return falseが効かない
-
javascriptでセレクトボックス...
-
連想配列からセレクトボックス...
-
複数プルダウンで検索
-
【JavaScript】プルダウンで数...
-
セレクトボックスで配列を呼び...
-
Selectボックスの一覧表示方法
-
VB6でWEBのラジオボタンの...
-
プルダウンの値によって活性・...
-
複数の画像を同じ位置に表示す...
-
<input>の選択肢をプルダウンメ...
-
return trueとreturn falseの用...
-
【jQuery】input nameの文字列...
-
プルダウンで選択すると、DBの...
-
ボタン無しでフォーム内容送信
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
javascriptでoptionタグを削除...
-
<input>の選択肢をプルダウンメ...
-
プルダウン選択を変更すると、...
-
selectを変更不可にしたい
-
javascriptでセレクトボックス...
-
スマホのフォームでのselect複...
-
プルダウンメニューの件でお願...
-
【JS】selectでchangeした時の...
-
Selectボックスの一覧表示方法
-
AxWebBrowserで開いたWebページ...
-
selectを使った計算
-
selectボックスで選択数を制限...
-
プルダウンメニューのvalue値を...
-
セレクトボックスで選択した内...
-
セレクトメニューの値の取得
-
ラジオボタンとプルダウンを連...
-
プルダウンの選択内容を次のペ...
-
C#(csファイル)とjavascriptと...
-
複数のプルダウンを1つにまとめ...
-
同じ名前のセレクトがある場合...
おすすめ情報