bootstrap的popover动态元素绑定问题

使用的bootstrap的popover时,元素是通过ajax向服务器请求返回的,但是这个动态生成的元素无法绑定popover的初始化函数popover()。不知道这个怎么才能正常绑定进行初始化。
尝试通过点击元素时,调用popover('toggle')。但是这样需要点击两下才可以正常显示内容。但是如果在调用popover('toggle')前面加上popover(),可以正常显示,但是这样每次点击都会调用popover()进行初始化。

阅读 8.3k
2 个回答

應該要在請求返回並放入 Body 時進行綁定

$(function () {

  // $('[data-toggle="popover"]').popover()
  
  fakeDom(function(dom) {
    $dom = $(dom)
    // 這裡就應該預先初始化了
    $dom.popover()
    $('body').append($dom)
  })
  
})

function fakeDom(callback) {

    setTimeout(function() {
        callback && callback('<button type="button" class="btn btn-lg btn-danger" data-toggle="popover" title="Tooltip">異步載入</button>')
    }, 1000)

}

jsFiddle

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏