
BOM浏览器对象模型.docx
15页web 前端培训教程:BOM 浏览器对象模型BOM 也叫浏览器对象模型,它提供了很多对象,用于访问浏览器的功能 BOM 缺少规范,每个浏览器提供商又按照自己想法去扩展它,那么浏览器共有对象就成了事实的标准所以, BOM 本身是没有标准的或者还没有哪个组织去标准它一. window 对象BOM 的核心对象是 window,它表示浏览器的一个实例 window 对象处于 JavaScript 结构的最顶层,对于每个打开的窗口,系统都会自动为其定义 window 对象1.对象的属性和方法window 对象有一系列的属性,这些属性本身也是对象window 下的属性和方法,可以使用 window.属性、 window.方法() 或者直接属性、方法()的方式调用例如: window.alert()和 alert()是一个意思2.系统对话框浏览器通过 alert()、 confirm()和 prompt()方法可以调用系统对话框向用户显示信息系统对话框与浏览器中显示的网页没有关系,也不包含 HTML//弹出警告alert('Lee'); //直接弹出警告//确定和取消confirm('请确定或者取消'); //这里按哪个都无效if (confirm('请确定或者取消')) { //confirm 本身有返回值alert('您按了确定! '); //按确定返回 true} else {alert('您按了取消! '); //按取消返回 false}//输入提示框var num = prompt('请输入一个数字', 0); //两个参数,一个提示,一个值alert(num); //返回值可以得到//调出打印及查找对话框print(); //打印find(); //查找defaultStatus = '状态栏默认文本'; //浏览器底部状态栏初始默认值status='状态栏文本 '; //浏览器底部状态栏设置值3.新建窗口使用 window.open()方法可以导航到一个特定的 URL,也可以打开一个新的浏览器窗口。
它可以接受四个参数: 1.要加载的 URL; 2.窗口的名称或窗口目标; 3.一个特性字符串; 4.一个表示新页面是否取代浏览器记录中当前加载页面的布尔值open(''); //新建页面并打开百度open('','baidu'); //新建页面并命名窗口并打开百度open('','_parent'); //在本页窗口打开百度,_blank 是新建PS:不命名会每次打开新窗口,命名的第一次打开新窗口,之后在这个窗口中加载窗口目标是提供页面的打开的方式,比如本页面,还是新建 本身返回 window 对象var box = open();box.alert(''); //可以指定弹出的窗口执行 alert();//子窗口操作父窗口document.onclick = function () {opener.document.write('子窗口让我输出的! ');}3.窗口的位置和大小用来确定和修改 window 对象位置的属性和方法有很多 IE、 Safari、 Opera 和 Chrome 都提供了 screenLeft 和 screenTop 属性,分别用于表示窗口相对于屏幕左边和上边的位置。
Firefox 则在 screenX 和 screenY 属性中提供相同的窗口位置信息, Safari 和 Chrome 也同时支持这两个属性//确定窗口的位置,IE 支持alert(screenLeft); //IE 支持alert(typeof screenLeft); //IE 显示 number,不支持的显示 undefined//确定窗口的位置,Firefox 支持alert(screenX); //Firefox 支持alert(typeof screenX); //Firefox 显示 number,不支持的同上PS: screenX 属性 IE 浏览器不认识,直接 alert(screenX), screenX 会当作一个为声明的变量,导致不执行那么必须将它将至为 window 属性才能显示为初始化变量应有的值,所以应该写成: alert(window.screenX)//跨浏览器的方法var leftX = (typeof screenLeft == 'number') ? screenLeft : screenX;var topY = (typeof screenTop == 'number') ? screenTop : screenY;窗口页面大小, Firefox、 Safari、 Opera 和 Chrome 均为此提供了 4 个属性: innerWidth 和 innerHeight,返回浏览器窗口本身的尺寸; outerWidth 和 outerHeight,返回浏览器窗口本身及边框的尺寸。
alert(innerWidth); //页面长度alert(innerHeight); //页面高度alert(outerWidth); //页面长度+ 边框alert(outerHeight); //页面高度+边框PS:在 Chrome 中, innerWidth=outerWidth、 innerHeight=outerHeight;PS: IE 没有提供当前浏览器窗口尺寸的属性;不过,在后面的 DOM 课程中有提供相关的方法在 IE 以及 Firefox、 Safari、 Opera 和 Chrome 中, document.documentElement.clientWidth 和 document.documentElement.clientHeight 中保存了页面窗口的信息PS:在 IE6 中,这些属性必须在标准模式下才有效;如果是怪异模式,就必须通过document.body.clientWidth 和 document.body.clientHeight 取得相同的信息//如果是 Firefox 浏览器,直接使用 innerWidth 和 innerHeightvar width = window.innerWidth; //这里要加 window,因为 IE 会无效 var height = window.innerHeight;if (typeof width != 'number') { //如果是 IE,就使用 documentif (patMode == 'CSS1Compat') {width = document.documentElement.clientWidth;height = document.documentElement.clientHeight;} else {width = document.body.clientWidth; //非标准模式使用 bodyheight = document.body.clientHeight;}}PS:以上方法可以通过不同浏览器取得各自的浏览器窗口页面可视部分的大小。
patMode 可以确定页面是否处于标准模式,如果返回 CSS1Compat 即标准模式//调整浏览器位置moveTo(0,0); //IE 有效,移动到 0,0 坐标moveBy(10,10); //IE 有效,向下和右分别移动 10 像素//调整浏览器大小resizeTo(200,200); //IE 有效,调正大小resizeBy(200,200); //IE 有效,扩展收缩大小PS:由于此类方法被浏览器禁用较多,用处不大4.间歇调用和超时调用JavaScript 是单线程语言,但它允许通过设置超时值和间歇时间值来调度代码在特定的时刻执行前者在指定的时间过后执行代码,而后者则是每隔指定的时间就执行一次代码超时调用需要使用 window 对象的 setTimeout()方法,它接受两个参数:要执行的代码和毫秒数的超时时间setTimeout("alert('Lee')", 1000); //不建议直接使用字符串function box() {alert('Lee');}setTimeout(box, 1000); //直接传入函数名即可setTimeout(function () { //推荐做法alert('Lee');}, 1000);PS:直接使用函数传入的方法,扩展性好,性能更佳。
调用 setTimeout()之后,该方法会返回一个数值 ID,表示超时调用这个超时调用的 ID 是计划执行代码的唯一标识符,可以通过它来取消超时调用要取消尚未执行的超时调用计划,可以调用 clearTimeout()方法并将相应的超时调用 ID 作为参数传递给它var box = setTimeout(function () { //把超时调用的 ID 复制给 boxalert('Lee');}, 1000);clearTimeout(box); //把 ID 传入,取消超时调用间歇调用与超时调用类似,只不过它会按照指定的时间间隔重复执行代码,直至间歇调用被取消或者页面被卸载设置间歇调用的方法是 setInterval(),它接受的参数与 setTimeout()相同:要执行的代码和每次执行之前需要等待的毫秒数setInterval(function () { //重复不停执行alert('Lee');}, 1000);取消间歇调用方法和取消超时调用类似,使用 clearInterval()方法但取消间歇调用的重要性要远远高于取消超时调用,因为在不加干涉的情况下,间歇调用将会一直执行到页面关闭。
var box = setInterval(function () { //获取间歇调用的 IDalert('Lee');}, 1000);clearInterval(box); //取消间歇调用但上面的代码是没有意义的,我们需要一个能设置 5 秒的定时器,需要如下代码:var num = 0; //设置起始秒var max = 5; //设置最终秒setInterval(function () { //间歇调用num++; //递增 numif (num == max) { //如果得到 5 秒clearInterval(this); //取消间歇调用, this 表示方法本身alert('5 秒后弹窗! ');}}, 1000); //1 秒一般认为,使用超时调用来模拟间歇调用是一种最佳模式在开发环境下,很少使用真正的间歇调用,因为需要根据情况来取消 ID,并且可能造成同步的一些问题,我们建议不使用间歇调用,而去使用超时调用var num = 0;var max = 5;function box() {num++;if (num == max) {alert('5 秒后结束! ');。
