javascript – event.stopPropagation()在jQuery 1.7中不能使用chrome
作者:互联网
出于某种原因,单击文档无法在Chrome中运行(未调用closeQuickView).
这些元素是通过AJAX加载的,因此需要有.on()动作(之前的.live()现已在jQuery 1.7中弃用)
使用此处给出的示例:How do I detect a click outside an element?作为基础
$('html').on('click', '.poster:not(.active) .image-effect', function (event) {
var obj = $(this).parent();
// If there are no .close spans
if (obj.find('.close').length === 0) {
// Add the close element by javascript to remain semantic
obj.find('.quick-view').append('<span class="close">×</span>');
}
// Close any open Quick Views
closeQuickView();
// Add the active class (controls opacity)
obj.addClass('active');
// Fade in the Quick View
obj.find('.quick-view').fadeIn(200, 'easeInOutQuint');
event.preventDefault();
event.stopPropagation();
});
$('html').on('click', '.active', function () {
return false;
});
$('html').on('click', '.close', function () {
closeQuickView();
});
$('html').on('click', '.quick-view', function (event) {
event.stopPropagation();
});
// Close the QuickView with a button
$('html').on('click', function () {
closeQuickView();
});
function closeQuickView() {
$('.poster').removeClass('active');
$('.quick-view').fadeOut(200, 'easeInOutQuint');
}
我的标记如下:
<figure class="grid_2 box poster">
<a class="image-effect" href="#">
<img class="colour" src="path/to/image" />
<img class="bw" src="path/to/image" />
</a>
<div class="quick-view">
Content
</div>
</figure>
解决方法:
尝试event.stopImmediatePropagation
标签:jquery,javascript,html5,event-propagation,stoppropagation 来源: https://codeday.me/bug/20190613/1235340.html