我有一个带有许多图片的网页。在桌面上,当我将鼠标移到桌面上时,我会看到一个带有额外细节的覆盖图。
<li>
<div class="pic">
<div class="overlay touch">
<div class="content">extra content here</div>
</div>
<img src="image.jpg" alt="" >
</div>
</li>
由于mouseover事件在移动设备(特别是iOS)上不起作用,我使用以下脚本来捕获移动触摸并显示覆盖:
$(".touch").on("mouseenter mouseleave touchstart", function(e){
if(e.type == 'touchstart') {
$(this).off('mouseenter mouseleave');
}
$(this).toggleClass("hover");
});
这一切都很好,但现在我希望覆盖隐藏在第二次点击手机。
目前,如果另一个元素或页面上的“空白”区域被点击,覆盖将会隐藏。
我怎么才能让覆盖隐藏在第二次“触摸”点击?
发布于 2018-07-23 01:27:16
如果设备小于767px,第一次单击将显示内容,第二次将隐藏内容。
if($(window).width() < 767) {
$('.touch').click(function() {
$(this).find('.content').toggle();
});
}
只要确保CSS中的.content
为display:none
即可。
https://stackoverflow.com/questions/51467150
复制相似问题