BOM浏览器对象模型
一、BOM简介
- BOM浏览器对象模型:BOM可以通过JS来操作浏览器,在BOM中为我们提供了一组对象,用来完成对浏览器的操作。
- BOM对象有Window、Navigator、Location、History、Screen。这些BOM对象在浏览器中作为window对象的属性保存的,可以通过window对象来使用,也可以直接使用。
- window代表的是整个浏览器的窗口,同时window也是网页中的全局对象;
- navigator代表当前浏览器的信息,通过该对象可以识别不同的浏览器;
- location代表当前浏览器的地址栏信息,或者操作浏览器跳转页面;
- history代表浏览器的历史记录,可以通过该对象来操作浏览器的历史记录.由于隐私原因,该对象不能获取到具体的历史记录,只能操作浏览器向前或向后翻页,而且该操作只在当次访问时有效。
- screen(几乎不用):代表用户的屏幕信息,通过该对象可以获取到用户的显示器的相关信息。
二、Navigator对象
- 由于历史原因 ,navigator对象的大部分属性都已经不能帮助我们识别浏览器了,一般我们使用userAgent来判断浏览器的信息。userAgent是一个字符串,这个字符串中包含有用来描述浏览器信息的内容,不同的浏览器有不同的userAgent.
var a=navigator.userAgent;
if(/firefox/i.text(a)){
alert("我是火狐");
}
- 在IE11中已经将微软和IE相关的标识去除了,所以我们基本不能通过userAgent来识别一个浏览器是否是IE了。除了userAgent,还可以通过一些浏览器中特有的对象来识别浏览器。比如AciveXObject是IE浏览器中特有的对象。
if("ActiveXObject" in window){
alert("我是IE");
}
三、History对象
- length属性:返回浏览器历史列表中的URL数量。
- back()方法:可以用来回退到上一个页面,作用和浏览器的回退按钮一样。
- forward()方法:可以跳转到下一个页面,作用和浏览器的前进按钮一样。
- go()方法:可以跳转到指定页面,它需要一个整数作为参数。1表示向前跳一个,-1表示向后跳。
四、Location对象
- 如果直接打印location,则可以获取地址栏的信息(当前页面完整的路径),如果将location属性修改为一个完整的路径或相对路径,则页面会自动跳转到该路径并且会自动生成历史记录。
- 属性:port、protocol、pathname、hostname等,分别是设置并返回当前URL的端口号、协议、路径部分、主机名。
- assign()方法:用来跳转到其他页面,作用和直接修改location一样。
- reload()方法:用于重新加载当前页面,作用和刷新按钮一样。如果在方法中传递一个true作为参数,则页面会强制清空缓存刷新页面。
- replace()方法:可以使用一个新的页面替换当前页面,调用完毕也会跳转页面。replace()方法不会生成历史记录,不能使用回退按钮回退。
四、Window对象
- window对象表示浏览器中打开的窗口,之前也学过了很多window对象的属性和方法。
- JS的程序执行速度是非常快的,如果希望一段程序,可以每隔一段时间执行一次,可以使用定时器。setInterval():定时调用可以将一个函数每隔一段时间执行一次,参数:回调函数和每次调用间隔的时间,会返回一个Number类型的数据用来作为定时器的唯一标识。
- clearInterval():可以关闭一个定时器,方法中需要一个定时器的标识作为参数,这样将关闭标识对应的定时器。
- 延时调用setTimeout()和关闭延时调用clearTimeout():一个函数不马上执行,而是隔一段事件后执行,而且只会执行一次。延时调用和定时调用的区别,定时调用会执行很多次,而延时调用只会执行一次。延时调用和定时调用实际上是可以相互代替的,在开发中可以根据需要选择。