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();}