2016-08-02 11 views
-1

マウス入力イベントと組み合わせてChromeがクリックイベントを完全に無視するシナリオを見つけました。これがChromeまたはjQueryの既知のバグであるかどうか不思議です。子要素が削除されたときにChromeがクリックハンドラをリッスンしない

以下の例は、この例を示しています。 'hover-add'クラスを表示しているアイテムの真上または真下のセルにマウスをドラッグし、 '.cell-item'をクリックすると、クリックイベントに登録されていません。ただし、セルの左側または右側からクリックすると、クリックイベントに登録されます。

https://jsfiddle.net/smoq36yp/

<div class='container'> 
    <div class='col' data-col='0'> 
    <div class='cell' data-row='2' data-col='0'></div> 
    <div class='cell hover-add' data-row='1' data-col='0'> 
     <div class='cell-item'></div> 
    </div> 
    <div class='cell filled' data-row='0' data-col='0'> 
     <div class='cell-item'></div> 
    </div> 
    </div> 
</div> 

# if you move the mouse in from above or below to the cell in row 1, 
# this click event (or others put on the body, etc.) does not fire 
$('.cell:not(.filled)').click (event) -> 
    mgr.addItem(event) 
$('.cell:not(.filled)').mouseenter (event) -> 
    mgr.hoverInAddItem(event) 
+0

クロームVに私のために働くようだ51 – Adjit

+0

クロームVに私のために働くようだ52 – gaetanoM

+1

私はこれをしたまではスクリーンキャスト.MOVがブラウザにロードされませんいくつかの理由:。。https://support.apple .com/en-us/HT205081 .movを直接スクリーンキャストにアップロードしたからかもしれません。 Jing https://www.techsmith.com/jing.htmlはスクリーンキャストのビデオキャプチャを行うための無料のツールであり、screencast.comでうまく動作します。私はSnagIt https://www.techsmith.com/snagit.htmlを使用していますやや多くの機能(注釈など)を持つjingの有料版です。 HTH! – jfroom

答えて

1

私はJSFiddleリンクで問題を再現することができました。

.cell-item {pointer-events: none;}を追加すると、目的の動作が表示されます。

.cell-item.cellに追加されると、Chromeのイベントハンドラ(および/またはjQuery?)が混乱しているようです。ホバーアイテムが追加されると、他の奇妙な動作が見られます。複数の「マウスセンター」イベントがマウスオーバーしている間にトリガーし、「クリック」が「マウスセンター」を奇妙にトリガーします。別の方法として、.cell-itemのクリックアイテムをバインドすることで解決できるかもしれませんが、上記の少しのCSSがそれを修正して以来、私はそれを探っていませんでした。

希望すると便利です。

+0

これは、ありがとうございます!私はまだクローム/ jqueryがこの奇妙な動作をしている理由を知りたいです! – Julie

関連する問題