BOM的补充

Posted zhangli123

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了BOM的补充相关的知识,希望对你有一定的参考价值。

1.首先我们要知道BOM是干什么的?

BOM和DOM、ES是javascript的重要三个组成部分;

Bom的核心操作是window;简单来说就是用来操作浏览器的,他是js访问浏览器的接口,它里面封装了dom和bom的所有的方法。

这里为什么会封装dom的方法大家可能有点疑问

我们可以这样来理解我们用作用域来解释,如果我们是全局作用域,我们可以理解就是在Window下的,前面我们知道bom的核心操作是window,所以说我们的好多操作都是在BOm里面操作的

2.接下来我们来看BOM下面有哪些子对象(我这里列举的是我们比较常用的)

(1).doncument:这是我们dom的,主要的是操作html的API的

(2).event:事件对象,事件在其中发生的元素、键盘按键的状态、鼠标的位置、鼠标按钮的状态

什么时候会产生Event 对象呢? 

当用户单击某个元素的时候,我们给这个元素注册的事件就会触发,该事件的本质就是一个函数,而该函数的形参接收一个event对象。

事件通常与函数结合使用,函数不会在事件发生前被执行!

事件流:

当我们看到event就会想到事件的冒泡

什么是冒泡:假如用户单击了一个元素,该元素拥有一个click事件,那么同样的事件也将会被它的祖先触发,这个事件从该元素开始一直冒泡到DOM树的最上层,这一过程称为事件冒泡

这里我找到了几张图可以帮助我们理解一下

技术图片

 

技术图片

 

事件的冒泡是有下到上的(记住这里的this是跟随着父元素移动的)

竟然有冒泡行为,那肯定有阻止冒泡的行为

这里提供两种:

event.stopPropagation();

event.CanlelBubble=ture;//老版本IE独有

捕获:由上到下,记录各父级元素上绑定的相同的事件

目标出发:触发目标元素上的事件处理函数

(3)history:浏览器历史记录

属性:length返回浏览器中历史列表中的URL的数量

        封装当窗口打开后,成功访问过的URL历史记录栈

方法:back()后一个URL

          forWord()前一个URL

          go();某一个具体页面的数值,0为刷新

(4)location:窗口的URL地址栏信息

     属性:.href:保存完整的URL地址

              .protocol   http  https

              .host   端口号   hostname  主机名          port 端口号

              .path   相对路径

              .hash 锚点 哈希

             . search  查询字符串

   方法:assign(“URL”);在当前窗口打开新的URL地址

            replace(“URL”);在当前窗口打开新的URL地址,禁止后退,因为使用新的URL替换旧的URL

           reload(false/true);重新加载当前页面

(5)screen显示设备的信息

(6)浏览器的配置信息

接下来是几个坐标事件

e.screenX   e.screenY  相当于屏幕的

e.clientX    e.clientY相当于文本显示区

e.offsetX   e.offsetY  相对于当前元素的

这几个不要记混了

 

ele.offsetHeight//元素在网页的实际高度

ele.offsetWidth/元素在网页的实际宽度

我们还要注意

我们在js当中添加的样式是行内样式,当我们拿外部样式是拿不到的;我们在js里面想拿外部样式可以通过

getcomputedStyle(ele).width  他是不可改的

 

 

 

以上是关于BOM的补充的主要内容,如果未能解决你的问题,请参考以下文章

JS补充

bom

python 自动化之路 day 18 前端内容回顾补充/Django安装创建

[手机按键备忘]常见的脚本结构思路的补充(强化了错误代码的处理部分个人向)

今年最后一篇

采购中的术语是啥意思,如:PR,PO,RFQ,RFI,SOW,BOM,JIT,VMI,MRO