2015-02-05 77 views
0

我同時使用了懸停和mouseenter,mouseout,但兩者都是一樣的。如何消除懸停閃爍?

我該如何停止閃爍。

HTML

<div class="pro_img_border"> 
      <div class="pro_img" id="pro_img_1"> 
      </div> 
      <div class="pro_img-txt" id="img_1-komal"> 
        hover text... 
      </div> 
     </div> 

<div class="pro_img_border_1"> 
      <div class="pro_img" id="pro_img_2"> 
      </div> 
      <div class="pro_img-txt" id="img_2-komal"> 
        hover text... 
      </div> 
     </div>` 

CSS

.pro_img_border{ 
     border: 1px dotted #000; 
     border-radius: 150px; 
     width: 221px; 
     height: 221px; 
     padding: 10px; 
     margin: 0px auto; 
    } 
    .pro_img{ 
     z-index:0; 
     border-radius: 150px; 
     background-color: #cccccc; 
     width: 221px; 
     height: 221px; 
     margin: 0 auto; 
     position: absolute;   
     cursor: pointer; 
    } 

    .pro_img-txt{ 
     border-radius: 150px; 
     background-color: rgba(202, 140, 140, 0.52); 
     width: 221px; 
     height: 221px; 
     margin: 0 auto; 
     position: absolute; 
     line-height: 19; 
     font-size: 20px; 
     color: rgba(1, 0, 0, 1); 
     display: none; 
     z-index:10; 
    } 

jQuery的

$('.pro_img_border #pro_img_1').mouseenter(function(){ 
       $("#img_1-komal").show(); 


      }); 
      $('.pro_img_border #pro_img_1').mouseleave(function() { 
        $('#img_1-komal').hide(); 

     }); 

$('.pro_img_border_1 #pro_img_2').hover(function(){ 
       $("#img_2-komal").show(); 


      }, function() { 
        $('#img_2-komal').hide(); 

     }); 

JSFIDDLE

回答

2
$('.pro_img_border').mouseenter(function(){ 
      $("#img_1-komal").show(); 


     }); 
     $('.pro_img_border').mouseleave(function() { 
       $('#img_1-komal').hide(); 

    }); 
+0

爲什麼你使用父元素?是否有任何其他解決方案與子元素? – 2015-02-05 13:54:38

+0

,因爲當你顯示第二個div時,懸停或moveleave事件觸發自動,因爲先前的div將低於新的div,並且你的移動現在指向新的/秒div 可能有,但鼠標事件將觸發爲光標將指向新的div – dharmesh 2015-02-05 13:58:10