BOM是Browser Object Mode的缩写,表示浏览器对象模型。ES是一种语言,跟具体环境没关系。DOM的作用是将文档转换为相应的对象,它跟具体环境也没有关系。而DOM则是一种将浏览器这个具体的环境对应为一种对象的模型,它提供了ES跟浏览器之间进行交互的桥梁。 因为DOM没有自己的标准,所以不同浏览器的实现细节并不相同,但是它们还是有很多统一的地方。 虽然BOM没有自己的标准,但是HTML5标准中对BOM中的对象都做了相应的规定。如果浏览器实现HTML5标准,那么BOM的结构也就有望趋向统一,这会使前端开发中令人无奈的浏览器兼容性问题得到一定改善。
window对象是浏览器中的顶层对象,其他所有的对象都直接或间接包含它下面,但是,通过window对象只能直接操作它自己直接包含的属性对象,而无法操作更深层次的对象。
window对象中跟窗口、框架相关的属性有:window、self、frames、length、top、parent和frameElement 7个属性。
其中,前三个(window、self、frames)都是指向window对象自身,它们所代表的内容完全相同,知识所使用的场景不同。widow中的length属性指页面中所包含的框架数量top属性表示最顶层框架parent表示上层框架,对于本来就是最顶层的window对象来说,top和parent属性就是自身frameElement属性是框架窗口中用来获取(iframe)框架节点自身用的。frameElement属性是HTMLIFrameElement类型,这是在DOM的HTML子标准中定义的类型,它一共有10个可读写属性,每个均对应一个iframe标签的属性,另外还有一个只读属性(contentDocument:获取框架所包含的document对象)。 10个可读写属性如下:
align: 排列方式,可以取left、right、top、middle、bottom等值,最好使用样式来设定,而不要使用align值frameBorder: 框架的边框src: 框架显示文档的地址height: 框架的高度width: 框架的宽度longDesc: 长描述,可以指定一个URL来存放iframe的描述信息marginHeight:框架的上、下边距marginWidth: 框架的左、右边距name: 框架的名称scrolling: 是否显示框架的滚动条window对象除了上述属性外,还包含其他一些属性,这些属性主要包括三大类:ES中的全局属性、自定义属性(包括自定义的全局变量)和不同浏览器特有的属性。 因为window对象同时还是ES中的Global对象,所以它还会包含ES中的全局属性。例如,NaN、undefined,以及Function、String、Array等所有的内置性对象。
个人wx:iotzzh 前端公众hao:前端微说