js中老师说这是事件冒泡事件,冒泡不是从内到外吗?

为什么在父级上加的事件 在子节点上会触发 子节点不是没有加事件吗

首先纠正你一个重要的概念:事件是被动触发的,并不是你能主动“加”上去的。换句话说,元素只要符合某种事件的触发条件(比如鼠标点击),事件就必定会触发,而你所谓的“加”上去的是js对事件的处理过程(没有加的话就不会对事件做任何处理,但并不等于说事件就没有触发)。
对事件冒泡的正确理解是这样的:当div1内包含div2时,用户把鼠标移到div2上,会触发div2的onmouseover,然后,div2又会把这个事件冒泡(也可以理解为上报)给自己的父元素div1,这样div1的onmouseover事件也会被触发(如果div1上面还有上级元素也会被触发,直到顶级元素html)。这时候就要看所有被触发onmouseover事件的元素有没有添加对事件的处理程序,有就会按由内到外的顺序逐级处理,没有就会像什么也没发生一样。
所以,我最后再强调一遍,能不能理解就看你造化了:
div1.onmouseover=function(){...}
并不是说你加了这段代码div1就会触发onmouseover事件,而是说当div1触发onmouseover事件时就会执行function内的代码!
温馨提示:答案为网友推荐,仅供参考
第1个回答  2018-07-04
对,你定义在父节点,点击子节点冒泡到父节点,这个是能接收到的,但是你没有定义子节点的事件所以收不到