2个回答
展开全部
首先纠正你一个重要的概念:事件是被动触发的,并不是你能主动“加”上去的。换句话说,元素只要符合某种事件的触发条件(比如鼠标点击),事件就必定会触发,而你所谓的“加”上去的是js对事件的处理过程(没有加的话就不会对事件做任何处理,但并不等于说事件就没有触发)。
对事件冒泡的正确理解是这样的:当div1内包含div2时,用户把鼠标移到div2上,会触发div2的onmouseover,然后,div2又会把这个事件冒泡(也可以理解为上报)给自己的父元素div1,这样div1的onmouseover事件也会被触发(如果div1上面还有上级元素也会被触发,直到顶级元素html)。这时候就要看所有被触发onmouseover事件的元素有没有添加对事件的处理程序,有就会按由内到外的顺序逐级处理,没有就会像什么也没发生一样。
所以,我最后再强调一遍,能不能理解就看你造化了:
div1.onmouseover=function(){...}
并不是说你加了这段代码div1就会触发onmouseover事件,而是说当div1触发onmouseover事件时就会执行function内的代码!
对事件冒泡的正确理解是这样的:当div1内包含div2时,用户把鼠标移到div2上,会触发div2的onmouseover,然后,div2又会把这个事件冒泡(也可以理解为上报)给自己的父元素div1,这样div1的onmouseover事件也会被触发(如果div1上面还有上级元素也会被触发,直到顶级元素html)。这时候就要看所有被触发onmouseover事件的元素有没有添加对事件的处理程序,有就会按由内到外的顺序逐级处理,没有就会像什么也没发生一样。
所以,我最后再强调一遍,能不能理解就看你造化了:
div1.onmouseover=function(){...}
并不是说你加了这段代码div1就会触发onmouseover事件,而是说当div1触发onmouseover事件时就会执行function内的代码!
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询