浏览器对象模型(BOM): 1、 宿主对象 2、 提供了很多对象,用于访问浏览器的功能,这些功能与任何网页内容无关 3、 将浏览器中的各个部分转换成一个一个的对象,我们通过修改这些对象的属性,调用他们的方法,从而控制浏览器的各种行为 简单来说:BOM可以使我们通过JS来操作浏览器,在BOM中提供了一组对象,用于完成对浏览器的操作 (这些BOM对象在浏览器中都是作为window对象的属性保存,可通过window对象来使用,也可以直接使用) 1、 window对象:代表整个浏览器窗口、同时window也是网页中的全局对象{
2、 Navigator对象:代表的当前浏览器的信息,通过该对象可以来识别不同的浏览器 userAgent(不能用来识别IE浏览器)、ActiveXobject(专门用来识别IE浏览器) 不同的浏览器通过useragent、activeXobject识别出来的浏览器信息也不同 浏览器兼容:
var web = navigator.userAgent; //获取浏览器信息 if (/firefox/i.test(web)) { alert("这是火狐浏览器"); } else if (/Chrome/i.test(web)) { alert("这是谷歌浏览器"); } else if ("ActiveXObject" in window) { alert("这是IE浏览器"); }3、 Location:代表浏览器的地址栏信息,通过location可以获取地址栏信息,或则操作浏览器页面跳转 (1)地址栏说明:
(2) hash 设置或返回从井号 (#) 开始的 URL(锚)。 host 设置或返回主机名和当前 URL 的端口号。 hostname 设置或返回当前 URL 的主机名。 href 设置或返回完整的 URL。 pathname 设置或返回当前 URL 的路径部分。 port 设置或返回当前 URL 的端口号。 protocol 设置或返回当前 URL 的协议。 search 设置或返回从问号 (?) 开始的 URL(查询部分)。
(3) -assign()用来跳转到其他页面,与location的修改类似, -reload()重新加载当前文档,作用域刷新按钮一样 如果传递一个true作为参数,则会强制清空缓存、刷新页面 -raplace()-用新的地址替换当前的文档地址,调用完毕会跳转页面、、-不会生成历史记录、不能使用回退按钮
4、 History:代表浏览器的历史记录,可以通过该对象来操作浏览器的历史记录 由于隐私问题该对象不能获取到具体的历史记录,只能操作浏览器向前或向后翻页,而且该操作只在当次访问时有效{ Length:返回返回浏览器历史列表中的 URL 数量。 1、 history.back() //后一页 2、 history.forward() //前一页 3、 history.go(1) //前一页 4、 history.go(-1) //后一页
} 5、 Screen:代表用户的屏幕的信息,通过该对象可以获取到用户的显示器的相关信息 { availHeight:返回屏幕的高度(不包括window的任务栏)。
availWidth:返回屏幕的宽度(不包括window的任务栏)。
height:返回屏幕的总高度。
width:返回屏幕的总宽度。
colorDepth:返回设备上调色板的比特深度。
pixelDepth:返回屏幕的颜色分辨率(像素的位数)。