如何通过事件更改弹出窗口的延迟?

时间:2019-05-16 09:11:48

标签: javascript jquery twitter-bootstrap-3 bootstrap-popover

我试图在单击时在Bootstrap弹出窗口中更改延迟选项。我希望结果是这样,当您单击第二个按钮时,弹出窗口会立即显示,但是没有,我也不知道为什么。

我尝试使用disposedisablehide,但它们都不起作用。有人有什么想法吗?

$('[data-toggle="popover"]').popover({
  trigger: "hover",
  delay: {
    show: 1000,
    hide: 150
  }
})

$('#popOnAnother').click((event) => {
  $('#popOnIt').popover('toggle')
})
<script type="text/javascript" src="//code.jquery.com/jquery-3.3.1.slim.min.js"></script>
<link rel="stylesheet" type="text/css" href="//stackpath.bootstrapcdn.com/bootstrap/4.1.0/css/bootstrap.min.css">
<script type="text/javascript" src="//cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.0/umd/popper.min.js"></script>
<script type="text/javascript" src="//stackpath.bootstrapcdn.com/bootstrap/4.1.0/js/bootstrap.min.js"></script>
<link rel="stylesheet" type="text/css" href="https://stackpath.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css">

<button id="popOnIt" data-toggle="popover" data-content="work please">
  I want to pop after deley on hover
</button>
<button id="popOnAnother">
  show pop on another button RIGHT NOW!
</button>

jsFiddle:https://jsfiddle.net/L4tmhux1/11/

1 个答案:

答案 0 :(得分:2)

您可以将带有Popover元素的Button包装在div中,而不是切换按钮的Popover,而是在包装器上创建新的Popover并进行切换。

<div id="wrap">
  <button id="popOnIt" data-toggle="popover" data-content="work god damn it">
     I want to pop after deley on hover
  </button>
</div>


$('#popOnAnother').click((event)=>{
  $('#wrap').popover({
    content: $('#popOnIt').data('content')
  }).popover('toggle');
});

JSFiddle