JavaScriptの「document.write」の正体&「alert」などダイアログやブラウザー操作の基本JavaScript標準ライブラリの使い方超入門(7)(4/5 ページ)

» 2016年11月08日 05時00分 公開
[金城俊哉]

ウィンドウがおかしな位置に出現するとまずいですよね

 Windowオブジェクトには、ウィンドウの表示位置やサイズ、さらにはスクロール位置を指定するメソッドが用意されています。

ウィンドウの位置とサイズを変更するメソッド

theme

ページ上に3個のボタンを配置し、ボタンクリックで表示位置の移動、画面のリサイズ、スクロールを行うプログラムを作成する。ただし、Internet Explorerのみに対応するプログラムとする。


Navigator

「ウィンドウの位置やサイズを変更するメソッドには、次のように、位置やサイズを直接指定するメソッドと、現在の位置やサイズを基準にした相対的な指定を行うメソッドがあります」


ウィンドウの位置やサイズを変更するメソッド
メソッド 説明
window.moveBy(x, y) ウィンドウを現在の位置から指定したぶんだけ移動する。xは移動する水平方向の距離、yは垂直方向の距離。
window.moveTo(X,Y) ウィンドウの位置を座標(X,Y)の位置に移動する。Xは画面の左端からの距離、Yは上端からの距離。
window.resizeBy(x, y) 現在のウィンドウサイズにx、yの値を加算、または減算したサイズに変更する。
window.resizeTo(X, Y) ウィンドウサイズをX(幅)、Y(高さ)のサイズに変更する。
window.scroll(X, Y) ウィンドウ内のページをウィンドウの左上隅を基点として、X(横方向)、Y(縦方向)のぶんだけスクロールする。
window.scrollBy(x, y) x(横方向)、y(縦方向)のぶんだけスクロールする。
Navigator

「しかし、Google Chrome、Firefox、Operaでは、window.scroll()、window.scrollBy()以外のメソッドは非対応です


Driver

「スクロール以外はできないということですか」


Navigator

「これはユーザーの画面を直接、操作するのが好ましくないというか、必要ないという考えじゃないでしょうか」


Driver

「じゃ、これから作るプログラムはInternet Explorerのみ対応ってことですね」


Attention

Internet Explorer8.0では、複数のタブが開いていると移動やリサイズが行われないので注意してください。


Navigator

「そうなのですが、メソッド自体はWindowオブジェクトに用意されているので、どのような機能なのかってことを確認だけでもしておきましょう。なお、位置やサイズ以外に、次のメソッドも用意されています」


フォーカスや印刷に関するメソッド
メソッド 説明
window.blur() ウィンドウからフォーカスを外す。
window.focus() ウィンドウにフォーカスを合わせる。
window.print() ウィンドウ内のページを印刷するための印刷ダイアログを開く。

ウィンドウの位置、サイズの変更とスクロールを行う

Navigator

「では、ページ上に3個のボタンを配置し、ボタンクリックで表示位置の移動、画面のリサイズ、スクロールを行うプログラムを作成してみましょう。なお、スクロールの位置がわかるように、1〜5の数字を縦に並べて配置してください」


Driver

「行番号のように見せるのですね。では、1つ目のボタンでウィンドウの位置を変更、2つ目のボタンでウィンドウサイズを変更、3つ目のボタンでスクロールができるようにしてみます」


表示位置の移動、リサイズ、スクロールを行うボタンを配置(move_scroll.html)
実行結果

Attention 新規のウィンドウがタブで開かれないようにする

 現在のブラウザーは同一のウィンドウにタブを利用して別のウィンドウを開くタイプが主流です。このようなブラウザーでは、window.open()メソッドのオプションが何も指定されていないと、タブでウィンドウが開かれます。

 これを防止するにはwindow.open()に何か1つでもよいのでオプションを指定するようにします。これによって、タブではなく新規のブラウザーウィンドウが開くようになります。


Copyright © ITmedia, Inc. All Rights Reserved.

RSSについて

アイティメディアIDについて

メールマガジン登録

@ITのメールマガジンは、 もちろん、すべて無料です。ぜひメールマガジンをご購読ください。