如何覆盖Twitter Bootstrap中的样式?例如,我当前正在使用一个包含CSS规则'float:left;'的.sidebar类。我该如何更改它,使其向右浮动?我正在使用HAML和SASS,但对Web开发相对较新。
如何覆盖Twitter Bootstrap中的样式?例如,我当前正在使用一个包含CSS规则'float:left;'的.sidebar类。我该如何更改它,使其向右浮动?我正在使用HAML和SASS,但对Web开发相对较新。
bootstrap.css
)之后包含您的CSS(site-specific.css
),则可以通过重新定义规则来覆盖它们。<head>
中包含CSS的方式。<link rel="stylesheet" href="css/bootstrap.css" />
<link rel="stylesheet" href="css/site-specific.css" />
您可以通过在您的site-specific.css
文件中编写以下内容来将侧边栏简单地移动到右侧:
.sidebar {
float: right;
}
请原谅我没有使用 HAML 和 SASS,因为我不太熟悉它们,无法撰写有关它们的教程。
.sidebar.right
比.sidebar
更具体。那可能就是问题所在。使用Web检查工具找出覆盖它的内容。 - citelao!important
的问题在于你将来永远无法再次覆盖它。 - citelaoSite.css
被捆绑并列在Bundle.config
中,并在bootstrap.css
之后物理呈现,但样式仍未被覆盖。我不得不将site.css
的引用从modernizer捆绑包中移除,并手动将其放在bootstrap.css
之后(在调试时按Ctrl + F5清除缓存)。 - atconway<nav class="navbar navbar-inverse navbar-fixed-top" role="navigation">
<div id="home-menu-container" class="collapse navbar-collapse">
<ul id="home-menu" class="nav navbar-nav">
<li><a class="navbar-brand" href="#"><img src="images/xd_logo.png" /></a></li>
<li><a href="#intro">Home</a></li>
<li><a href="#about">About Us</a></li>
<li><a href="#services">What We Do</a></li>
<li><a href="#process">Our Process</a><br /></li>
<li><a href="#portfolio">Portfolio</a></li>
<li><a href="#contact">Contact Us</a></li>
</ul>
</div><!-- /.navbar-collapse -->
</nav>
在这里,你需要记住特异性的层次结构。它是这样的:
因此,对于上述内容,如果你的CSS文件中有以下样式:
.navbar ul li a { color: red; } /* 10(.navbar) + 1(ul) + 1(li) + 1(a) = 13 points */
.navbar a { color: green; } /* 10(.navbar) + 1(a) = 11 points */
.navbar ul li a
之后定义了.navbar a
,由于特异性更高(13个点),它仍然会使用红色而不是绿色进行覆盖。.navbar-inverse .navbar-nav>li>a { /* Total = 22 points */
color: #999;
}
.navbar-nav li a {
color: red;
}
即使它的渲染值为#999,为了解决这个问题,Bootstrap有22个点(需要自己计算)。因此,我们需要使用更多的内容。所以,我已经向元素添加了自定义ID,即home-menu-container和home-menu。现在以下CSS将起作用:
#home-menu-container #home-menu li a { color: red; } /* 100 + 100 + 1 + 1 = 202 points :) */
完成了。
您可以参考这个MDN链接。
blockquote
样式时遇到了麻烦。奇怪的是,对于普通的引用块,它是错误的,但对于引用块内的<ul>
看起来是正确的。关键是更新我的CSS以具有blockquote p
,这足够优先级。<ul>
正在为页面的另一部分执行此操作。 - Adam Wuerl添加自己的 class,例如:<div class="sidebar right"></div>
,其对应的 CSS 样式为
.sidebar.right {
float:right
}
你可以通过使CSS类“更具体”来覆盖它。
你需要沿着HTML树向上,指定父元素:
div.sidebar { ... }
比 .sidebar { ... }
更具体
如果需要,你可以一直向上到BODY:
body .sidebar { ... }
会覆盖几乎所有的东西。
查看这个方便的指南:http://css-tricks.com/855-specifics-on-css-specificity/
您只需确保您的css文件在boostrap.css之后解析,像这样:
<link href="css/bootstrap.css" rel="stylesheet">
<link href="css/myFile.css" rel="stylesheet">
如果您想覆盖Bootstrap中的任何CSS,请使用!important
假设这是Bootstrap中的页面头部类,其顶部有40像素的边距,我的客户不喜欢它,他只希望顶部为15像素,底部为10像素
.page-header {
border-bottom: 1px solid #EEEEEE;
margin: 40px 0 20px;
padding-bottom: 9px;
}
.page-header
{
padding-bottom: 9px;
margin: 15px 0 10px 0px !important;
}
我晚些时候看到了这个问题,但我认为它还需要另一个答案。
如果您正在使用sass,您实际上可以在导入bootstrap之前更改变量。http://twitter.github.com/bootstrap/customize.html#variables
更改其中任何一个变量,例如:
$bodyBackground: red;
@import "bootstrap";
如果没有可用于更改所需内容的变量,您可以覆盖样式或添加自己的样式。
Sass:
如果没有可用的变量来更改所需的内容,您可以覆盖样式或添加自己的样式。@import "bootstrap";
/* override anything manually, like rounded buttons */
.btn {
border-radius: 0;
}
还可以查看这个: 在Rails中正确使用SCSS资源结构
我知道这是一个老问题,但我还是遇到了类似的问题,并且我意识到我在bootstrapOverload.css
文件中的“不工作”的CSS代码是写在媒体查询
之后的。当我将其移动到媒体查询之前时,它开始工作。
以防其他人也面临同样的问题。