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来实现动画导航效果的代码
Dec 16 Javascript
Javascript YUI 读码日记之 YAHOO.util.Dom - Part.3
Mar 22 Javascript
JavaScript计算字符串中每个字符出现次数的小例子
Jul 02 Javascript
javascript loadScript异步加载脚本示例讲解
Nov 14 Javascript
JS文字球状放大效果代码分享
Aug 19 Javascript
微信小程序实现点击按钮修改view标签背景颜色功能示例【附demo源码下载】
Dec 06 Javascript
如何从零开始利用js手写一个Promise库详解
Apr 19 Javascript
vue-cli 3.x 修改dist路径的方法
Sep 19 Javascript
JavaScript私有变量实例详解
Jan 24 Javascript
Cordova(ionic)项目实现双击返回键退出应用
Sep 17 Javascript
Vue+webpack实现懒加载过程解析
Feb 17 Javascript
vue 点击其他区域关闭自定义div操作
Jul 17 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之第五天
2006/10/09 PHP
php批量更改数据库表前缀实现方法
2013/10/26 PHP
Laravel模型间关系设置分表的方法示例
2018/04/21 PHP
高亮显示web页表格行的javascript代码
2010/11/19 Javascript
一样的table?不一样的table(可编辑状态table)
2012/09/19 Javascript
javascript中的parseInt和parseFloat区别
2013/07/12 Javascript
jquery 获取dom固定元素 添加样式的简单实例
2014/02/04 Javascript
javascript实现unicode与ASCII相互转换的方法
2015/12/10 Javascript
JS中call/apply、arguments、undefined/null方法详解
2016/02/15 Javascript
JS中input表单隐藏域及其使用方法
2017/02/13 Javascript
微信小程序 弹幕功能简单实例
2017/02/14 Javascript
angularjs实现下拉列表的选中事件示例
2017/03/03 Javascript
Mac系统下Webstorm快捷键整理大全
2017/05/28 Javascript
浅谈react.js中实现tab吸顶效果的问题
2017/09/06 Javascript
JS简单实现点击跳转登陆邮箱功能的方法
2017/10/31 Javascript
Vue 源码分析之 Observer实现过程
2018/03/29 Javascript
vue将毫秒数转化为正常日期格式的实例
2018/09/16 Javascript
vue移动端屏幕适配详解
2019/04/30 Javascript
解决Element中el-date-picker组件不回填的情况
2020/11/07 Javascript
[05:15]2018年度CS GO社区贡献奖-完美盛典
2018/12/16 DOTA
python的urllib模块显示下载进度示例
2014/01/17 Python
Python中shutil模块的常用文件操作函数用法示例
2016/07/05 Python
使用Python的Scrapy框架十分钟爬取美女图
2016/12/26 Python
手把手教你使用Python创建微信机器人
2019/04/29 Python
Python 使用office365邮箱的示例
2020/10/29 Python
Django restful framework生成API文档过程详解
2020/11/12 Python
台湾SHOPRO购物行家:亚洲首创影视.3C.家电.优质购物平台
2018/05/07 全球购物
2014基层党员干部学习全国两会心得体会
2014/03/17 职场文书
优秀学生干部先进事迹材料
2014/05/26 职场文书
工地宣传标语
2014/06/18 职场文书
综治工作心得体会
2014/09/11 职场文书
婚宴新娘致辞
2015/07/28 职场文书
SqlServer数据库远程连接案例教程
2021/07/15 SQL Server
Go并发4种方法简明讲解
2022/04/06 Golang
Python matplotlib安装以及实现简单曲线的绘制
2022/04/26 Python
如何利用python实现Simhash算法
2022/06/28 Python