当position:sticky遇到bootstrap浮动布局时候的注意事项
小编给大家分享一下当position:sticky遇到bootstrap浮动布局时候的注意事项,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
10余年的安国网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。成都全网营销的优势是能够根据用户设备显示端的尺寸不同,自动调整安国建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。成都创新互联公司从事“安国网站设计”,“安国网站推广”以来,每个客户项目都认真落实执行。
当第一次接触到 position:sticky
这个属性,我就意识到之前的不少 js 场景可以用这个 css 属性去改写。譬如 网站 右侧的不少广告,滚动上去后需要 fixed,完全就是 sticky 的应用啊。
今天要说的是 文章详情页 右侧的目录栏,当页面下滑的时候,它也会固定到页面顶部,之前是用 js 去监听 scroll 事件,然后根据位置进行判断,toggle fixed 的方案,出于一些原因,决定对它用 sticky 去重写。
几下就写完了,去掉滚动事件监听,然后将菜单元素 .post-nav
加上 position:sticky; top:0
样式,但是,不起效!
wtf! 百思不得其解,我开始搜索原因。在 so 搜到了 这个,说到可能是元素的父级元素有对 overflow 属性进行处理,比如加了什么 overflow:hidden
啥的,但是看了下,并没有这种情况。
然后我猜想会不会是 bootstrap 布局的问题(事实上确实有关系),写下 demo:
content
menu
ad
others
但是没问题,突然想到网站用的 bootstrap 版本是 3.x,然后改成 3.3.7 的版本,这时候问题就出来了。
这时候问题就比较好定位了,4.x 用的是 flex 布局,而 3.x 还是 float 浮动布局,问题应该是出在这里了。
最终代码(参考 这个 issue):
content
menu
ad
others
对应到开始的问题上,因为 menu 是属于 .col-md-3
元素的,所以右边的 .col-md-3
需要和左边的 .col-md-9
保持高度一致即可,加上这行代码:
$('.side').height($('.main').height())
因为左边的内容区域有图片的延迟加载,所以这行代码需要持续执行:
$(window).scroll(function() { $('.side').height($('.main').height()) // other code // ... })
以上是“当position:sticky遇到bootstrap浮动布局时候的注意事项”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!
新闻名称:当position:sticky遇到bootstrap浮动布局时候的注意事项
URL分享:http://azwzsj.com/article/jgjsgo.html