我试图仅在显示模式处于活动状态的情况下运行一些 javascript。问题是,无论模态是否处于活动状态,我尝试过的方法都是 True 。下面是我想要完成的一个例子。我试过:是可见的方法,也是:活动的。我正在使用 zurb 显示模式。
的HTML:
<div id="myModal" class="reveal-modal">
<ul>
<li>some list item</li>
<li>some list item</li>
</ul>
</div> <!--/myModal-->
JS:
<script>
if ($('#myModal:active').length){
console.log('yes'); //always yes even when not revealed
} else {
//do nothing
}
</script>
//also tried if ($('#myModal').hasClass('someClass'))
编辑
活动时有“可见性”的CSS:“可见”,否则“隐藏”所以我尝试了以下内容,但它没有响应条件。任何想法为什么会发生这种情况?
if($("#myModal").css("visibility", "hidden").length > 0) {
console.log('is hidden');
} else {
console.log('is shown');
}
这是带有Zurb用于显示弹出窗口选项的 cookie 代码。
if (document.cookie.indexOf('visited=true') == -1) {
var tenYears = 3600 * 1000 * 24 * 365 * 10; //1000*60*60*24*15;//15days
var expires = new Date((new Date()).valueOf() + tenYears);
document.cookie = "visited=true;expires=" + expires.toUTCString() + ";path=/"; //encodeURIComponent +
// Zurb's popup reveal modal
$('#myModal').reveal({
animation: 'fadeAndPop',
animationspeed: 100,
closeonbackgroundclick: true,
dismissmodalclass: 'close-reveal-modal'
});
}