行いたいこと
tableタグにあるTHREDタグとTBODYタグがあり、現在はTBODYタグの任意行を選択するとその行の色が変わるようになっています。
サーバアクションで画面遷移を行ったりした後、その画面に戻ってくる時に以前選択されていた行が存在したらそこで色が変わるようにしています。
そこで問題なのですが、その画面に戻ってきた時にしたのほうが選択行だった場合フォーカスが当たり、すくロースして表示してないと一瞬どこいった?という風に感じてしまいます。なので、そこの行まで飛ばしてやりたいのですが、できるでしょうか?
選択行の色変えには以下の関数を作って行っています。
function syncroData(){
for(var i = 1 ; i < table10.rows.length ; i++){
if(i == hojirowid){
table10.rows[i].style.backgroundColor = "yellow";
} else{
if(i%2 == 0){
table10.rows[i].style.background = "#fff8dc";
}else{
table10.rows[i].style.background = "#f5fffa";
}
}
}
試しにfor文が終わった後に
table10.rows[i].focus();
と記述してみましたが、そういうメソッドが使えないのかそこまで飛んでくれませんでした(もしかしたら、フォーカスだけあたってスクロールしなかっただけ?)
以上、宜しくお願い致します。
No.3ベストアンサー
- 回答日時:
スクロールさせたい位置を調べて、scrollTo すればよいのでは?
var node = table10.rows[i];
var y = 0;
while (node.tagName.toUpperCase() != "BODY") {
y += node.offsetTop;
node = node.parentNode;
}
window.scrollTo(0, y);
※インデントは全角空白なので、コピーする場合はタブなどに変えてください。
レスが遅れました・・・・・納期ぎりぎりでやってたもんで・・・・
scrollToメソッドについては知りませんでした・・
今回はできないということで、相手側に伝えてしまったので、次回以降に役立てたいと思います。
ありがとうございました。
No.2
- 回答日時:
私の解釈が間違っているかも・・・
表の任意行までスクロールさせたいのなら表の各行に
こんな↓感じで<a name=..">を入れておいて
<table>
<tr><td><a name="001">A</a></td><td>B</td><td>c</td></tr>
<tr><td><a name="002">A</a></td><td>B</td><td>c</td></tr>
</table>
戻るときに
document.location.href="hoge.html#002"
とか
<a href="hoge.html#002">もどる</a>
とやれば、その行のあたりが表示されますので、
「#002」の部分を動的に変更してやれば良さそうですが。。。。
レスが遅れました・・・・・納期ぎりぎりでやってたもんで・・・・
今回のテーブルの中身はxmlでのBindDataで処理を行っているため、単純にaタグを入れ込めそうにありませんでした。
今後の参考にしたいと思います。ありがとうございました。
No.1
- 回答日時:
僕の知っている範囲では、できないと思いますが。
。。ちょっと誤解がある様なので、
> 試しにfor文が終わった後に
> table10.rows[i].focus();
> と記述してみましたが、そういうメソッドが使えないのかそこまで飛んでくれませんでした(もしかしたら、フォーカスだけあたってスクロールしなかっただけ?)
どうやら、フォーカスの意味を取り違えているようです。
フォーカスと言うのは、そのフォームの中の指定された名前を、処理の対象としますよ。と言う意味であって、そこへ移動しますよ。と言う意味ではありません。
なので、
> (もしかしたら、フォーカスだけあたってスクロールしなかっただけ?)
その通りです。
Webの場合、見ている人のブラウザ環境が同じであるとは限らないので、そう言う処理はサポートされていない。と言うパターンが多いのですよね。
レスが遅れました・・・・・納期ぎりぎりでやってたもんで・・・・
textareaなどは、focusを当てるとそこに飛ぶのでスクロールするのですが、この場合はあくまでテーブルにフォーカスが当たっているようで、スクロールはしないようですね^^;
回答ありがとうございました
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- JavaScript javascriptでテーブルに追加した項目のid追加してローカルストレージを操作したい 5 2023/01/01 15:52
- Excel(エクセル) VBA : スクレイピングできない 4 2023/05/12 22:26
- PHP if(preg_match("/[^0-9]/",$gu_d)){意味を教えてください。 1 2022/05/06 05:37
- HTML・CSS 自身のHPにYouTube動画を貼り付けるのが出来なくなり困ってます 1 2022/11/11 10:44
- Visual Basic(VBA) Selenium.ChromeDriverの使い方について 7 2022/09/22 06:43
- JavaScript 画像の表示位置 3 2022/12/23 08:25
- HTML・CSS テーブルタグのセルの幅の一部だけを指定 1 2023/03/12 12:02
- JavaScript ①入力フォーム→②確認表示画面→③送信完了画面のコードを書いているのです、 入力フォームから受け取っ 2 2022/05/10 16:45
- HTML・CSS (Javascript)印刷するファイルに応じて印刷プレビュー画面で用紙を自動的に切り替えたい!! 2 2022/04/11 12:04
- その他(プログラミング・Web制作) pythonリストの特定の値を表示htmlで表示できない 2 2022/05/14 05:48
このQ&Aを見た人はこんなQ&Aも見ています
-
プロが教えるわが家の防犯対策術!
ホームセキュリティのプロが、家庭の防犯対策を真剣に考える 2組のご夫婦へ実際の防犯対策術をご紹介!どうすれば家と家族を守れるのかを教えます!
-
テーブルの任意の列を非表示にしたい
HTML・CSS
-
クリックされたセルの位置を取得するには?
JavaScript
-
一覧から選択した行の行番号を取得について
JavaScript
-
-
4
htmlでテーブル内にテキストボックスを作りたいのですが・・・
HTML・CSS
-
5
ダブルクォーテーションのreplaceの方法
JavaScript
-
6
jquery datatablesを使用 インプットタグに数値入力して行の合計金額を出したい
JavaScript
-
7
チェックボックス付きのテーブルから、チェックの付いた行のみの値を取得したい
JavaScript
-
8
DateTimePickerでに年月までしか選択できないようにしたいです。
Visual Basic(VBA)
-
9
画面表示とともにtableの指定の行位置を表示
JavaScript
-
10
Javascript_submit()完了後に処理したい
JavaScript
-
11
サブウィンドウを常に最前面に表示する
JavaScript
-
12
tableタグとformタグの組み合わせ
HTML・CSS
-
13
チェックされたラジオボタンにフォーカスを移動したい
JavaScript
-
14
<JavaScript>tableタグを入力不可にしたい。
JavaScript
-
15
CSSでreadonlyの機能はありますか?
その他(プログラミング・Web制作)
-
16
画面表示とともに、テーブルの横スクロール位置を指定したい
JavaScript
-
17
テーブルにおける行(セルにプルダウン含む)の追加方法
JavaScript
-
18
テキストエリア内の改行禁止
HTML・CSS
-
19
テーブルタグの中にdivを含めてはダメ?
HTML・CSS
-
20
focus()が上手くいかない
JavaScript
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
リンク色の変更
-
tableの任意行にfocusをあてる
-
TD内のチェックボックスの位置...
-
ラジオボタンとセルの連動
-
特定<table>内の<td>の色を変える
-
テーブルの変数について
-
JavaScriptで特定のtdタグにcla...
-
セルをドラッグで選択するときに、
-
ハイパーリンクを別ウインドウ...
-
PERL
-
JQueryでクリックされた文字を...
-
一覧から選択した行の行番号を...
-
netscapeでもinnerTextやinnner...
-
JavaScriptでテーブルをクリッ...
-
階層式メニューをtableタグ内に
-
【UWSC】HTML内のある部分を抽...
-
JavaScriptでテーブルの行入れ替え
-
return trueとreturn falseの用...
-
テキストボックス入力を半角英...
-
onClick="this.form.submit
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
jsで質問です。 displayプロパ...
-
javascriptで質問です。 displa...
-
ハイパーリンクを別ウインドウ...
-
JavaScriptで特定のtdタグにcla...
-
プルダウンで選択すると、DBの...
-
一覧から選択した行の行番号を...
-
tableの任意行にfocusをあてる
-
至急!GetElementById でtdの...
-
特定<table>内の<td>の色を変える
-
マウスをブラウザの外に出した...
-
添付画像のようなhtmlとcssのス...
-
スクロールバーの表示位置を変...
-
クリックされた罫表セルの行番...
-
チェックボックスにチェックが...
-
JavaScriptでテーブルの行入れ替え
-
HTML中のTABLEのデータを抽出す...
-
jquery datatablesを使用 イン...
-
JavaScriptでテーブルをクリッ...
-
階層式メニューをtableタグ内に
-
マウスオーバー時テーブルの背...
おすすめ情報