解决Bootstrap模态框切换时页面抖动 or页面滚动条
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了解决Bootstrap模态框切换时页面抖动 or页面滚动条,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2597字,纯文字阅读大概需要4分钟。
内容图文
![解决Bootstrap模态框切换时页面抖动 or页面滚动条](/upload/InfoBanner/zyjiaocheng/1277/69f77664bfc044a5be7859dfda78c368.jpg)
Bootstrap为了让所有的页面(这里指内容溢出和不溢出)显示效果一样,采取的方法如下:
当Modal显示时,设置body -- overflow:hidden;margin-right:15px;(设置15px是因为浏览器的滚动条占位是15px);(通过在modal显示时给body添加.modal-open类实现)
设置modal -- overflow:auto;overflow-y:scroll;
这样设置的效果是:
(1)当页面内容超出(即页面本身存在滚动条),则moda弹出后,原body滚动禁止,body的margin-right和modal的滚动条位置重叠,此时页面是不会出现抖动现象的;
(2)当页面内容未超出(即页面本身不存在滚动条),则modal弹出后,由于body设置了margin-right,会使得页面向左偏移,当modal关闭后,body的margin-right为0,页面向右偏移,就出现页面抖动。
根据上面的描述,解决页面抖动的思路是:
根据scrollHeight和clientHeight,分别在modal加载前和关闭时调整body的overflow、margin-right和.modal的overflow属性,以覆盖bootstrap.css中的样式
函数如下:
//解决Modal弹出时页面左右移动问题
Modal.prototype.adjustBody_beforeShow = function(){ var body_scrollHeight = $(‘body‘)[0].scrollHeight; var docHeight = document.documentElement.clientHeight; if(body_scrollHeight > docHeight){ $(‘body‘).css({ ‘overflow‘ : ‘hidden‘, ‘margin-right‘ : ‘15px‘ }); $(‘.modal‘).css({‘overflow-y‘:‘scroll‘}) }else{ $(‘body‘).css({ ‘overflow‘ : ‘auto‘, ‘margin-right‘ : ‘0‘ }); $(‘.modal‘).css({‘overflow-y‘:‘auto‘}) } } Modal.prototype.adjustBody_afterShow = function(){ var body_scrollHeight = $(‘body‘)[0].scrollHeight; var docHeight = document.documentElement.clientHeight; if(body_scrollHeight > docHeight){ $(‘body‘).css({ ‘overflow‘ : ‘auto‘, ‘margin-right‘ : ‘0‘ }); }else{ $(‘body‘).css({ ‘overflow‘ : ‘auto‘, ‘margin-right‘ : ‘0‘ }); } }
函数使用方法:
Modal.prototype.show = function (_relatedTarget) { this.adjustBody_beforeShow(); //...other code } Modal.prototype.hide = function (e) { this.adjustBody_afterShow(); //...other code }
但我是这样用的:
(function() { var Modal = {}; //解决Modal弹出时页面左右移动问题 Modal.adjustBody_beforeShow = function(){ var body_scrollHeight = $(‘body‘)[0].scrollHeight; var docHeight = document.documentElement.clientHeight; if(body_scrollHeight > docHeight){ $(‘body‘).css({ ‘overflow‘ : ‘hidden‘, ‘margin-right‘ : ‘15px‘ }); $(‘.modal‘).css({‘overflow-y‘:‘scroll‘}) }else{ $(‘body‘).css({ ‘overflow‘ : ‘auto‘, ‘margin-right‘ : ‘0‘ }); $(‘.modal‘).css({‘overflow-y‘:‘auto‘}) } } Modal.adjustBody_afterShow = function(){ var body_scrollHeight = $(‘body‘)[0].scrollHeight; var docHeight = document.documentElement.clientHeight; if(body_scrollHeight > docHeight){ $(‘body‘).css({ ‘overflow‘ : ‘auto‘, ‘margin-right‘ : ‘0‘ }); }else{ $(‘body‘).css({ ‘overflow‘ : ‘auto‘, ‘margin-right‘ : ‘0‘ }); } } $(‘#addAppModal‘).modal(‘hide‘); $(‘#addAppModal‘).on(‘show.bs.modal‘, function (event) { Modal.adjustBody_beforeShow(); }); $(‘#addAppModal‘).on(‘hidden.bs.modal‘, function (event) { Modal.adjustBody_afterShow(); }); })();
原文:http://my.oschina.net/deacyn/blog/508249
内容总结
以上是互联网集市为您收集整理的解决Bootstrap模态框切换时页面抖动 or页面滚动条全部内容,希望文章能够帮你解决解决Bootstrap模态框切换时页面抖动 or页面滚动条所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。