6

正如您在jQuery中看到的那样,我已经使用这个问题的答案来使 Bootstrap Popover 在外部单击时消失。现在我希望在右上角添加一个“x”,以在单击时关闭弹出窗口。

有没有一种简单的方法可以在弹出框的右上角创建一个可点击的“x”,点击后会关闭弹出框?

HTML:

<h3>Live demo</h3>
<div class="bs-docs-example" style="padding-bottom: 24px;">
    <a href="#" class="btn btn-large btn-danger" data-toggle="popover" title="A Title" data-content="And here's some amazing content. It's very engaging. right?">Click to toggle popover</a>
</div>

jQuery:

var isVisible = false;
var clickedAway = false;

$('.btn-danger').popover({
    html: true,
    trigger: 'manual'
}).click(function(e) {
    $(this).popover('show');
    clickedAway = false
    isVisible = true
    e.preventDefault()
});

$(document).click(function(e) {
    if (isVisible & clickedAway) {
        $('.btn-danger').popover('hide')
        isVisible = clickedAway = false
    } else {
        clickedAway = true
    }
});
4

2 回答 2

16

这是jQuery代码:

这个只是在右上角添加了 X 按钮:

            var isVisible = false;
            var clickedAway = false;

            $('.btn-danger').popover({
                    html: true,
                    trigger: 'manual'
                }).click(function(e) {
                    $(this).popover('show');
                    $('.popover-title').append('<button type="button" class="close">&times;</button>');
                    clickedAway = false
                    isVisible = true
                    e.preventDefault()
                });

            $(document).click(function(e) {
              if(isVisible & clickedAway)
              {
                $('.btn-danger').popover('hide')
                isVisible = clickedAway = false
              }
              else
              {
                clickedAway = true
              }
            });

只有在单击 X 按钮时才会关闭弹出窗口:

            $('.btn-danger').popover({
                    html: true,
                    trigger: 'manual'
                }).click(function(e) {
                    $(this).popover('show');
                    $('.popover-title').append('<button type="button" class="close">&times;</button>');
                    $('.close').click(function(e){
                        $('.btn-danger').popover('hide');
                    });
                    e.preventDefault();
                });
于 2013-03-25T03:12:12.887 回答
1

我知道这个问题已经得到了回答,但你的帖子对我有所帮助。偶然发现了一种更简单的方法来完成这个任务假设你有所有带有“.pop”类的弹出框,这应该可以解决你所有的问题

$('.pop').on({
  click:function(){
    $('.pop').not(this).popover('hide');
  }
});
于 2015-04-14T04:11:31.697 回答