5

我遇到了一个问题,我在 Bootstrap 模式中显示一些数据。此数据包含一个图标,我将其变成一个弹出框。当我将鼠标悬停在图标上时,弹出框显示并且一切正常,但是当我将鼠标远离图标时,不仅弹出框关闭,而且父模式也关闭。

我认为这与此处描述的问题相同。但是,发布的解决方案对我不起作用。我正在捕获弹出窗口的“隐藏”事件,但设置 e.cancelBubble = true 或调用 e.stopPropagation() 都不会阻止父模式关闭。

目前我面前没有我的代码,但这里有一个基于我的一般回忆的粗略模型......

HTML


<!-- ko with: myFoo -->
<div class="modal hide fade" data-bind="visible: isOpen">
    <div class="modal-header">
        <button type="button" class="close" data-bind="click: close">&times;</button>
        <h3>Title Bar!</h3>
    </div>
    <div class="modal-body">
        <!-- dynamically generated modal content goes here, including... -->
        <table>
            <tr>
                <td data-bind="popover: $data">
                    <i class="icon-question-mark" data-content="la la la..." />
                </td>
            </tr>
        </table>
    </div>
    <div class="modal-footer">
        <a href="#" class="btn" data-bind="click: close">Close</a>
    </div>
</div>
<!-- /ko -->

淘汰赛自定义绑定处理程序


ko.bindingHandlers.popover = {

    init: function(element)
    {
        $(element).children().andSelf().on("mousenter", "[data-content]"function() {
            var options = {...}
            $(this).popover(options).on("hidden", function(e) {
                e.cancelBubble = true;
                e.stopPropagation();
            });
        });
    }
};

有没有人对如何解决这个问题有任何想法/建议?

4

3 回答 3

3

归功于 afanasy,他在评论中提到了这一点:

$("[data-toggle=popover]").on("hidden", function (e) {
   e.stopPropagation();
});

注意:“隐藏”而不是“隐藏”。这适用于引导程序 2.3.2。

于 2014-03-04T21:01:07.343 回答
2
$("[data-toggle=popover]").on("hide", function (e) {
    e.stopPropagation();
});

为我解决了这个问题

于 2013-10-12T12:29:32.460 回答
0

事实证明,我需要捕获“隐藏”事件而不是“隐藏”事件,因为后者发生在模式已经关闭之后......最终解决方案见下文:

淘汰赛自定义绑定处理程序


define ["jquery", "ko", "bootstrap"], ($, ko) ->

    ko.bindingHandlers.popover =

        init: (element) ->

            $(element).children().andSelf().filter("[data-content]").popover()

            $(element).children().andSelf().on "hide", "[data-content]", (e) ->
                e.stopPropagation?()
                return
于 2013-07-12T16:00:48.400 回答