我将 Foundation 4.3.1 与 Reveal 4.3.2 和 jQuery 2.0.3 一起使用。我正在使用以下代码以编程方式成功打开模式:
$('.akita-modal-ajax').on('click', function (e) {
e.preventDefault();
var modalId = $(this).data('id'),
url = $(this).attr('href');
$('#' + modalId).foundation('reveal', 'open', {
url: url;
});
});
我用来尝试关闭模式的代码是:
$('.akita-modal').on('click', '.close-reveal-modal',function () {
console.log('click');
$('.akita-modal').foundation('reveal', 'close');
});
我的模态(一旦打开):
<div id="myModal" class="akita-modal open" style="display: block; opacity: 1; visibility: visible; top: 50px;">
<a class="close-reveal-modal">×</a>
...More content...
</div>
当我单击关闭模式时,它会在控制台中注册“单击”,但模式保持打开状态。有趣的是,如果我忽略我的自定义类并将“akita-modal”的所有引用恢复为“reveal-modal”,一切都会正常工作。但后来我坚持使用 Reveal 的默认样式。
我也试过:
$('.akita-modal').on('opened', function () {
$('.akita-modal').on('click', '.close-reveal-modal',function () {
console.log('click');
$('.akita-modal').foundation('reveal', 'close');
});
});
结果完全相同。“点击”被记录下来,但模式保持打开状态。我的控制台中没有其他错误,除了 JoelCDoyle 来回答另一个 SO 问题:Revealing a Modal in Foundation 4
如何使用我自己的类名关闭此模式?