BootStrap弹出框popover二次动态绑定问题

一般我们通过下面代码进行popover的初始化:

<div class="container" style="padding: 100px 50px 10px;" >
    <button type="button" class="btn btn-warning" title="Popover title"  
            data-container="body" data-toggle="popover" data-placement="right" 
            data-content="">
        右侧的 Popover
    </button>
    <button id="toggle" type="button" class="btn btn-success">toggle</button>
</div>
<div id="symbol_miss_popover_content_wrapper" style="display: none;">
    <div>囧...</div>
    <div>没有找到正确读音</div>
</div>
<div id="symbol_error_popover_content_wrapper" style="display: none;">
    <div>哇奥...</div>
    <div>服务器开了个小差</div>
</div>
</div>
<script>
$(function () { 
    $("[data-toggle='popover']").popover({});
});

假如现在你想对popover的内容进行修改,你可能会在初始化popover后面写这样的代码

    $("[data-toggle='popover']").popover("destory").popover({
        html: true,
        content: '<h1>test</h1>'
    });

但是很遗憾的是,这行代码并不起作用,.popover("destory").popover()是有问题的!

$("#toggle").on("click", function() {
        $("[data-toggle='popover']").popover("destroy");
        setTimeout(function() {
            $("[data-toggle='popover']").popover({
                html: true,
                content: function() {
                    return $("#symbol_error_popover_content_wrapper").html();
            }});
        }, 200);
        
    });

这样才是正确的,destroy和popover要分开调用,并且destroy后要加个延时初始化,否则可能会出现页面未重新绑定的情况。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,492评论 11 349
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 32,679评论 18 399
  • 一. Java基础部分.................................................
    wy_sure阅读 9,288评论 0 11
  • 一、语句 JavaScript语言的执行单位为line,也就是一行一行的执行。一般情况下,每一行为一个语句。 语句...
    寿木阅读 1,589评论 0 0
  • 青春,总有些事情想不好,说不破。然而,年少的我们,借着体内萌发的荷尔蒙,懵懂地做了很多事。 小冰,学习委员,老师眼...
    橙长日记阅读 3,669评论 8 5

友情链接更多精彩内容