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 相关文章推荐
extjs 学习笔记(一) 一些基础知识
Oct 13 Javascript
深入理解JavaScript系列(3) 全面解析Module模式
Jan 15 Javascript
固定表格行列(expression)在IE下适用
Jul 25 Javascript
js 实现 input type=&quot;file&quot; 文件上传示例代码
Aug 07 Javascript
Jquery实现弹性滑块滑动选择数值插件
Aug 08 Javascript
js如何判断输入字符串长度
Dec 16 Javascript
再次谈论React.js实现原生js拖拽效果引起的一系列问题
Apr 03 Javascript
jquery日历插件e-calendar升级版
Nov 10 Javascript
webpack vue项目开发环境局域网访问方法
Mar 20 Javascript
Angular中sweetalert弹框的基本使用教程
Jul 22 Javascript
解决vue路由后界面没有变化,但是链接有的问题
Sep 01 Javascript
解决Can't find variable: SockJS vue项目的问题
Sep 22 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 session_set_save_handler 函数的用法(mysql)
2013/06/29 PHP
PHP中常见的缓存技术实例分析
2015/09/23 PHP
Laravel5.7 Eloquent ORM快速入门详解
2019/04/12 PHP
jQuery1.3.2 升级到jQuery1.4.4需要修改的地方
2011/01/06 Javascript
循环 vs 递归浅谈
2013/02/28 Javascript
javascript利用apply和arguments复用方法
2013/11/25 Javascript
jQuery使用after()方法在元素后面添加多项内容的方法
2015/03/26 Javascript
JavaScript使用DeviceOne开发实战(一) 配置和起步
2015/12/01 Javascript
利用jQuery实现WordPress中@的ID悬浮显示评论内容
2015/12/11 Javascript
果断收藏9个Javascript代码高亮脚本
2016/01/06 Javascript
关于javascript的一些知识以及循环详解
2016/09/12 Javascript
实战node静态文件服务器的示例代码
2018/03/08 Javascript
详解开发react应用最好用的脚手架 create-react-app
2018/04/24 Javascript
JavaScript使用递归和循环实现阶乘的实例代码
2018/08/28 Javascript
webpack安装配置与常见使用过程详解(结合vue)
2020/06/01 Javascript
js实现简单音乐播放器
2020/06/30 Javascript
[46:44]DOTA2-DPC中国联赛 正赛 Ehome vs PSG.LGD BO3 第二场 3月7日
2021/03/11 DOTA
Python使用scrapy采集时伪装成HTTP/1.1的方法
2015/04/08 Python
Python爬虫:通过关键字爬取百度图片
2017/02/17 Python
Python爬虫实例爬取网站搞笑段子
2017/11/08 Python
分享一下Python数据分析常用的8款工具
2018/04/29 Python
python: 判断tuple、list、dict是否为空的方法
2018/10/22 Python
Python中的元组介绍
2019/01/28 Python
解决Pytorch 训练与测试时爆显存(out of memory)的问题
2019/08/20 Python
Jupyter notebook快速入门教程(推荐)
2020/05/18 Python
python3排序的实例方法
2020/10/20 Python
flask框架中的cookie和session使用
2021/01/31 Python
使用CSS3的::selection改变选中文本颜色的方法
2015/09/29 HTML / CSS
Html5 new XMLHttpRequest()监听附件上传进度
2021/01/14 HTML / CSS
美国知名男士服饰品牌:Brooks Brothers(布克兄弟)
2016/08/25 全球购物
PHP如何与mysql建立链接
2013/05/05 面试题
物流仓储计划书
2014/01/10 职场文书
中年人生感言
2014/02/04 职场文书
查摆问题自查报告范文
2014/10/13 职场文书
办公用品管理制度
2015/08/04 职场文书
php将xml转化对象的实例详解
2021/11/17 PHP