如何解决Boostrap栅格系统与自己额外定义媒体查询的冲突问题

小编给大家分享一下如何解决Boostrap栅格系统与自己额外定义媒体查询的冲突问题,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

创新互联建站企业建站,十多年网站建设经验,专注于网站建设技术,精于网页设计,有多年建站和网站代运营经验,设计师为客户打造网络企业风格,提供周到的建站售前咨询和贴心的售后服务。对于成都网站制作、网站建设中不同领域进行深入了解和探索,创新互联在网站建设中充分了解客户行业的需求,以灵动的思维在网页中充分展现,通过对客户行业精准市场调研,为客户提供的解决方案。

html结构如下


  
    
      1111
    

  
              2222     

  

我想要实现的效果是在屏幕宽度大于768时,1111左对齐,2222右对齐,小于等于768时居中对齐。于是我又额外写了媒体查询

@media (max-width: 768px) {
  .container-fluid .row p{
    color: #fff;
    font-size: 16px;
    text-align: center;
    line-height: 30px;
  }
  .row .text-left{
    margin-top: 20px;
  }
}

最终展示类似下图

如何解决Boostrap栅格系统与自己额外定义媒体查询的冲突问题

如何解决Boostrap栅格系统与自己额外定义媒体查询的冲突问题

看起来一切正常,但是却在临界点768px时出现了问题,如图

如何解决Boostrap栅格系统与自己额外定义媒体查询的冲突问题

打开控制台,会发现右边的两个图标的样式确实使用了text-align:center;,但是为什么展示出来呈现不一样的效果呢

如何解决Boostrap栅格系统与自己额外定义媒体查询的冲突问题

原因在于父级定义的栅格系统,查看.text-right的父级div,会发现它所占的宽度为50%

如何解决Boostrap栅格系统与自己额外定义媒体查询的冲突问题

因此在屏幕宽度为768px时,既有自己定义的样式,也有原来栅格系统的样式,所以导致混乱,根本原因在于没注意栅格系统的实质

/* 超小屏幕(手机,小于 768px) */
/* 没有任何媒体查询相关的代码,因为这在 Bootstrap 中是默认的(还记得 Bootstrap 是移动设备优先的吗?) */
/* 小屏幕(平板,大于等于 768px) */
@media (min-width: @screen-sm-min) { ... }
/* 中等屏幕(桌面显示器,大于等于 992px) */
@media (min-width: @screen-md-min) { ... }
/* 大屏幕(大桌面显示器,大于等于 1200px) */
@media (min-width: @screen-lg-min) { ... }

栅格系统是用min-width定义的,为大于等于,而我们额外定义的媒体查询用的是max-width,为小于等于,刚好有一个768px的重合,导致最终样式混乱。

解决办法:

去除交集,自己定义媒体查询时,定义max-width:767px

看完了这篇文章,相信你对“如何解决Boostrap栅格系统与自己额外定义媒体查询的冲突问题”有了一定的了解,如果想了解更多相关知识,欢迎关注创新互联行业资讯频道,感谢各位的阅读!


本文名称:如何解决Boostrap栅格系统与自己额外定义媒体查询的冲突问题
标题网址:http://myzitong.com/article/goijhh.html

其他资讯