BootStrap的弹出框(Popover)支持鼠标移到弹出层上弹窗层不隐藏的原因及解决办法
弹出框(Popover)与工具提示(Tooltip)类似,提供了一个扩展的视图。如需激活弹出框,用户只需把鼠标悬停在元素上即可。弹出框的内容完全可使用Bootstrap数据API(BootstrapDataAPI)来填充。该方法依赖于工具提示(tooltip)。
1设置延时,超过该延时未移入弹窗则弹窗隐藏
Tooltip.prototype.init=function{中的 vartriggers=this.options.trigger.split('')后面加上 //设置延时 if(this.options.trigger.indexOf('hover')>-1){ $.extend(true,this.options,{delay:{hide:100}}); }
2控制不消失代码
在Tooltip.prototype.enter=function(obj){中的
clearTimeout(self.timeout)后加入
if(self.options.trigger.indexOf('hover')>-1){ self.$tip.unbind('mouseenter').bind('mouseenter',function(e){ self.$tip.data('data-element',self.$element);//触发popover框的点击事件时可以获取id clearTimeout(self.timeout); self.hoverState='in'; }).unbind('mouseleave').bind('mouseleave',function(e){ self.hoverState='out'; self.timeout=setTimeout(function(){ if(self.hoverState=='out')self.hide() },self.options.delay.hide) }) }
bootstrap版本:v3.3.6
下面给大家补充弹出框(Popover)用法
弹出框(Popover)插件根据需求生成内容和标记,默认情况下是把弹出框(popover)放在它们的触发元素后面。您可以有以下两种方式添加弹出框(popover):
通过data属性:如需添加一个弹出框(popover),只需向一个锚/按钮标签添加data-toggle="popover"即可。锚的title即为弹出框(popover)的文本。默认情况下,插件把弹出框(popover)设置在顶部。
<ahref="#"data-toggle="popover"title="Examplepopover"> 请悬停在我的上面 </a>
通过JavaScript:通过JavaScript启用弹出框(popover):
$('#identifier').popover(options)
弹出框(Popover)插件不像之前所讨论的下拉菜单及其他插件那样,它不是纯CSS插件。如需使用该插件,您必须使用jquery激活它(读取javascript)。使用下面的脚本来启用页面中的所有的弹出框(popover):
$(function(){$("[data-toggle='popover']").popover();});