时间:2021-05-28
最近在项目中需要在Bootstrap Modal弹出框中载入CKEditor。
初始化CKEditor以后,在IE11下,格式/字体/颜色的下拉会闪现一下后就消失,但在chrome和firefox下没问题。
主要原因是IE11下,点击CKEditor,触发了focusin.modal事件,原modal enforceFocus函数的if条件成立,bootstrap modal获取焦点,CKEditor下拉失去焦点,所以下拉出现闪现。
Google了以后找到了一个解决方案
这个解决方案中,加了判断后,可以避免modal获取焦点,但好像modal一直都不会trigger了。
我做了一下修改,以下代码是在原modal enforceFocus函数的基础上添加了!$(e.target.parentNode).closest(".cke").length判断条件,也就是说在原判断条件+未点击在CKEditor上,则modal获取焦点。
代码的执行顺序是jQuery、bootstrap再执行此段代码。
$.fn.modal.Constructor.prototype.enforceFocus = function() { $(document) .off('focusin.bs.modal') .on('focusin.bs.modal', $.proxy(function (e) { if (document !== e.target && this.$element[0] !== e.target && !this.$element.has(e.target).length && !$(e.target.parentNode).closest(".cke").length) { this.$element.trigger('focus') } }, this))};在项目中测试了一下未发现问题。
附 bootstrap.js中enforceFocus函数代码对比
Modal.prototype.enforceFocus = function () { $(document) .off('focusin.bs.modal') // guard against infinite focus loop .on('focusin.bs.modal', $.proxy(function (e) { if (document !== e.target && this.$element[0] !== e.target && !this.$element.has(e.target).length) { this.$element.trigger('focus') } }, this)) }this.$element表示modal对象。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
当在bootstrap的modal中使用ckeditor时,使用ckeditor中带弹框的功能时无法输入问题。解决方法:在jquery和bootstrap加载之
在完成Win8.1系统更新后双击IE11图标,IE11浏览器竟然不能启动。那么WIN8.1的Metro界面IE打不开怎么办?下面小编就为大家介绍一下具体解决办法
如果用户在windows8.1操作系统中使用IE11浏览器,访问某些网站如果碰到一些兼容性的问题,又恰巧切换到兼容模式也无法解决的话,这时候IE11浏览器会出现
IE11拥有内置的flashplayer。如果flashplayer被意外卸载,导致打开浏览器提示安装,但下载后也无法安装上的解决方法,IE11的flashpl
许多安装Win8.1或者将IE浏览器升级到了最新版的IE11的朋友会发现,IE11浏览器界面非常简洁,加载速度明显提升,不过IE11浏览器由于过于简化,将我们在