DIV内有两个IMG 标签,该DIV和里面的两个IMG都有响应onclick消息,现在问题是单击里面的IMG标签,外层DIV的onclick也被调用了。要怎么改 才能保证 单击里面的IMG标签不会执行外层DIV的onclick消息。
回复讨论(解决方案)
写成这样的结构
然后用css控制就行了
阻止冒泡 http://lj830723.iteye.com/blog/1452280
写成这样的结构
然后用css控制就行了
亲,写成这样 页面布局就改了。DIV内也不只是两个IMG的,还有很多其它标签。
阻止冒泡 http://lj830723.iteye.com/blog/1452280
function stopPropagation(e) {
e = e || window.event;
if (e.stopPropagation) { //W3C阻止冒泡方法
e.stopPropagation();
} else {
e.cancelBubble = true; //IE阻止冒泡方法
}
}
function openchat(e,vId) {
stopPropagation(e);
}
刚试了下,还是不行。因为onclick是我要传一个ID进行。代码如上
写成这样的结构
然后用css控制就行了
亲,写成这样 页面布局就改了。DIV内也不只是两个IMG的,还有很多其它标签。
你只把这两个img标签独立出来就行了啊,用绝对定位放在div上面。我是这样想得,感觉应该可以。
阻止冒泡 http://lj830723.iteye.com/blog/1452280
function stopPropagation(e) {
e = e || window.event;
if (e.stopPropagation) { //W3C阻止冒泡方法
e.stopPropagation();
} else {
e.cancelBubble = true; //IE阻止冒泡方法
}
}
function openchat(e,vId) {
stopPropagation(e);
}
刚试了下,还是不行。因为onclick是我要传一个ID进行。代码如上 既然函数的event不能用,那你就用 window的event嘛,你就不要把e传进去,里面的方法就会取window的event了。也就是你这方法还是只接受一个参数,就是你传的id:
function stopPropagation(e) { e = e || window.event; if (e.stopPropagation) { //W3C阻止冒泡方法 e.stopPropagation(); } else { e.cancelBubble = true; //IE阻止冒泡方法 }} function openchat(vId) { stopPropagation();}