Tetingkap JavaScript - Model Objek Pelayar

Model Objek Penyemak Imbas (BOM)

Tiada standard formal untuk Model Objek Pelayar (BOM).

Kaedah dan sifat sering dianggap sebagai BOM kerana penyemak imbas moden telah melaksanakan (hampir) kaedah dan sifat yang sama untuk interaktiviti JavaScript.

objek tetingkap

Apabila penyemak imbas membuka dokumen, ia mencipta objek tetingkap, iaitu objek tetingkap mewakili tetingkap yang dibuka dalam pelayar.

Objek tetingkap ialah objek global, dan sifat tetingkap boleh digunakan sebagai pembolehubah global. Sebagai contoh, anda hanya boleh menulis dokumen dan bukannya window.document. Begitu juga, anda boleh menggunakan kaedah objek tetingkap semasa sebagai fungsi, seperti hanya menulis alert() dan bukannya Window.alert().

Jika dokumen mengandungi bingkai, penyemak imbas mencipta objek tetingkap untuk dokumen dan objek tetingkap tambahan untuk setiap bingkai.

Petua: Walaupun tiada standard yang jelas untuk objek tetingkap, semua penyemak imbas menyokongnya.

Dokumen HTML DOM juga merupakan salah satu atribut objek tetingkap:

window.document.getElementById("header");

Sama seperti ini :

document.getElementById("header");


Saiz tetingkap

Ada adalah tiga kaedah untuk menentukan Saiz tetingkap penyemak imbas (port pandang penyemak imbas, tidak termasuk bar alat dan bar skrol).

Untuk Internet Explorer, Chrome, Firefox, Opera dan Safari:

window.innerHeight - Ketinggian dalaman tetingkap penyemak imbas

window.innerWidth - Lebar dalaman bagi tetingkap penyemak imbas

Untuk Internet Explorer 8, 7, 6, 5:

document.documentElement.clientHeight

document.documentElement.clientWidth

atau

document.body.clientHeight

document.body.clientWidth

Penyelesaian JavaScript praktikal (merangkumi semua penyemak imbas):

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>php中文网(php.cn)</title>
</head>
<body>
<p id="demo"></p>
<script>
var w=window.innerWidth
|| document.documentElement.clientWidth
|| document.body.clientWidth;
var h=window.innerHeight
|| document.documentElement.clientHeight
|| document.body.clientHeight;
x=document.getElementById("demo");
x.innerHTML="浏览器window宽度: " + w + ", 高度: " + h + "。"
</script>
</body>
</html>

Kaedah Tetingkap Lain

Beberapa kaedah lain:

window.open() - Buka tetingkap baharu

window.close() - Tutup tetingkap semasa

window.moveTo() - Alihkan tetingkap semasa

window.resizeTo() - Laraskan saiz tetingkap semasa


Meneruskan pembelajaran
||
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>php中文网(php.cn)</title> <script type="text/javascript"> myWindow=window.open('','','width=200,height=100') myWindow.document.write("This is 'myWindow'") myWindow.moveTo(0,0) </script> </head> <body> <p>把新窗口移动到指定屏幕左上角(屏幕左上角为 0,0 坐标,往右和下计算为正)</p> </body> </html>
  • Cadangan kursus
  • Muat turun perisian kursus