BootStrap的弹出框(Popover)支持鼠标移到弹出层上弹窗层不隐藏的原因及解决办法


Posted in Javascript onApril 03, 2016

弹出框(Popover)与工具提示(Tooltip)类似,提供了一个扩展的视图。如需激活弹出框,用户只需把鼠标悬停在元素上即可。弹出框的内容完全可使用 Bootstrap 数据 API(Bootstrap Data API)来填充。该方法依赖于工具提示(tooltip)。

1 设置延时, 超过该延时未移入弹窗则弹窗隐藏

Tooltip.prototype.init = function{中的
var triggers = 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)设置在顶部。

<a href="#" data-toggle="popover" title="Example popover">
请悬停在我的上面
</a>

通过 JavaScript:通过 JavaScript 启用弹出框(popover):

$('#identifier').popover(options)

弹出框(Popover)插件不像之前所讨论的下拉菜单及其他插件那样,它不是纯 CSS 插件。如需使用该插件,您必须使用 jquery 激活它(读取 javascript)。使用下面的脚本来启用页面中的所有的弹出框(popover):

$(function () { $("[data-toggle='popover']").popover(); });
Javascript 相关文章推荐
用javascript实现兼容IE7的类库 IE7_0_9.zip提供下载
Aug 08 Javascript
ajax处理php返回json数据的实例代码
Jan 24 Javascript
javascript使用location.search的示例
Nov 05 Javascript
简单谈谈jQuery(function(){})与(function(){})(jQuery)
Dec 19 Javascript
JavaScript插件化开发教程 (三)
Jan 27 Javascript
Javascript BOM学习小结(六)
Nov 26 Javascript
JS实现简单的tab切换选项卡效果
Sep 21 Javascript
详解vue中axios的封装
Jul 18 Javascript
JavaScript实现美化滑块效果
May 17 Javascript
vue-cli设置publicPath小记
Apr 14 Javascript
JS使用Chrome浏览器实现调试线上代码
Jul 23 Javascript
Element Backtop回到顶部的具体使用
Jul 27 Javascript
js一维数组、多维数组和对象的混合使用方法
Apr 03 #Javascript
jQuery实现鼠标选文字发新浪微博的方法
Apr 02 #Javascript
JQuery解析XML的方法小结
Apr 02 #Javascript
javascript HTML5文件上传FileReader API
Mar 27 #Javascript
JavaScript中文件上传API详解
Apr 01 #Javascript
jquery表单验证插件formValidator使用方法
Apr 01 #Javascript
jquery分页插件jquery.pagination.js实现无刷新分页
Apr 01 #Javascript
You might like
PHP封装curl的调用接口及常用函数详解
2018/05/31 PHP
js 加载时自动调整图片大小
2008/05/28 Javascript
js创建元素(节点)示例
2014/01/02 Javascript
jQuery事件之键盘事件(ctrl+Enter回车键提交表单等)
2014/05/11 Javascript
JS函数重载的解决方案
2014/05/13 Javascript
js实现鼠标滚轮控制图片缩放效果的方法
2015/02/20 Javascript
JavaScript判断是否为数字的4种方法及效率比较
2015/04/01 Javascript
原生JS实现仿淘宝网左侧商品分类菜单效果代码
2015/09/10 Javascript
jQuery操作Table技巧大汇总
2016/01/23 Javascript
AngularJS 使用 UI Router 实现表单向导
2016/01/29 Javascript
JS组件系列之Bootstrap table表格组件神器【终结篇】
2016/05/10 Javascript
AngularJs 指令详解及示例代码
2016/09/01 Javascript
超全面的JavaScript开发规范(推荐)
2017/01/21 Javascript
JS+HTML5实现上传图片预览效果完整实例【测试可用】
2017/04/20 Javascript
基于Vue实现timepicker
2017/04/25 Javascript
React Native 环境搭建的教程
2017/08/19 Javascript
ES6中字符串string常用的新增方法小结
2017/11/07 Javascript
浅析从vue源码看观察者模式
2018/01/29 Javascript
vue组件中watch props根据v-if动态判断并挂载DOM的问题
2019/05/12 Javascript
JS中的函数与对象的创建方式
2019/05/12 Javascript
弱类型语言javascript中 a,b 的运算实例小结
2019/08/07 Javascript
使用vue实现多规格选择实例(SKU)
2019/08/23 Javascript
JS实现悬浮球只在一侧滑动并且是横屏状态下
2020/08/19 Javascript
Python求导数的方法
2015/05/09 Python
Python编程实现的简单Web服务器示例
2017/06/22 Python
python中实现精确的浮点数运算详解
2017/11/02 Python
python实现简单日志记录库glog的使用
2019/12/13 Python
Python tensorflow实现mnist手写数字识别示例【非卷积与卷积实现】
2019/12/19 Python
Python3将ipa包中的文件按大小排序
2020/04/17 Python
css3新增颜色表示方式分享
2014/04/15 HTML / CSS
Crocs欧洲官网:Crocs Europe
2020/01/14 全球购物
美国购物网站:Clickhere2shop
2021/01/28 全球购物
国际经济贸易专业推荐信
2013/11/06 职场文书
高中政治教学反思
2014/01/18 职场文书
Keras多线程机制与flask多线程冲突的解决方案
2021/05/28 Python
详解php中流行的rpc框架
2021/05/29 PHP