我想知道如何显示我的帖子“内联” 我开始使用CSS,我不知道在哪里放置代码显示:内联在我的css表上。我试试post,main_content,body,但它不起作用。你能解释一下如何做到这一点,我跟随了很多tuto,结果对我来说从来都不一样,所以我不明白该怎么做。
我的代码: 索引帖子视图:
<div class="transitions-enabled" id="post">
<%- @posts.each do |post|%>
<div class="row">
<div class="post">
<div class="panel-body">
<div class="form-group text-center">
<h3> <%=post.title%></h3>
</div>
</div>
<div class="box panel panel-default">
<div class="image_wrapper">
<%= link_to (image_tag post.image.url(:medium), class: 'img-responsive'), post_path(post)%>
</div>
</div>
<div class="panel-body">
<div class="form-group text-center">
<p><%= post.prix %></p>
</div>
</div>
</div>
</div>
<%end%>
</div>
&安培;我的申请css:
@import "bootstrap-sprockets";
@import "bootstrap";
@mixin box-shadow {
-webkit-box-shadow: rgba(0, 0, 0, 0.09) 0 2px 0;
-moz-box-shadow: rgba(0, 0, 0, 0.09) 0 2px 0;
box-shadow: rgba(0, 0, 0, 0.09) 0 2px 0;
}
$red: #DB6161;
body {
background: rgb(235, 238, 243);
}
.main_content {
padding: 0 0 50px 0;
}
.alert {
padding: 15px;
margin-bottom: 20px;
border: 1px solid transparent;
border-radius: 5px;
@include box-shadow;
background: white;
font-weight: bold;
}
.navbar {
margin-bottom: 50px;
@include box-shadow;
border: none;
.navbar-brand {
text-transform: uppercase;
letter-spacing: -1px;
font-weight: bold;
font-size: 25px;
a {
color: $red;
}
}
}
.post {
background: white;
border-radius: 5px;
margin-bottom: 40px;
@include box-shadow;
float: left;
.image_wrapper {
width: 400px;
height: 300px;
border-radius: 5px 5px 5px 5px;
overflow: hidden;
}
img {
width: 100%;
-webkit-transition: all .3s ease-out;
-moz-transition: all .3s ease-out;
-o-transition: all .3s ease-out;
transition: all .3s ease-out;
&:hover {
transform: scale(1.075);
}
.panel-body {
padding: 35px;
h1 {
margin: 0 0 10px 0;
}
.description {
color: #868686;
line-height: 1.75;
margin: 0;
}
}
}
h2 {
padding: 15px 5%;
margin: 0;
font-size: 20px;
font-weight: normal;
line-height: 1.5;
a {
color: $red;
}
}
}
#post_top {
margin-bottom: 50px;
}
#post_info, #ingredients, #directions {
background: white;
@include box-shadow;
min-height: 360px;
border-radius: 5px;
padding: 2em 8%;
}
.post_image {
max-width: 100%;
border-radius: 5px;
@include box-shadow;
}
#post_info {
h1 {
font-size: 36px;
font-weight: normal;
color: $red;
}
.description {
color: #8A8A8A;
font-size: 20px;
}
}
#ingredients, #directions {
margin-bottom: 50px;
ul, ol {
padding-left: 18px;
li {
padding: 1em 0;
border-bottom: 1px solid #EAEAEA;
}
}
}
.form-inline {
margin-top: 15px;
}
.form-input {
width: 65% !important;
float: left;
}
.form-button {
float: left;
width: 30% !important;
margin-left: 5%;
}
.add-button {
margin-top: 25px;
}
答案 0 :(得分:2)
除了CSS样式,你遇到的问题是你在每个帖子周围添加了row
课程。
假设您要在每行中显示三个帖子,请执行以下操作:
<%- @posts.each_slice(3) do |posts| %>
<div class="row">
<%- posts.each do |post|
...
<% end %>
</div>
<% end %>
更新:刚刚意识到原始代码示例未显示,尽管已将其标记为已回答。更新以显示示例。
或者只是将.row
div移到each
块之外,这会将所有帖子放在一个.row
内。
答案 1 :(得分:1)
在使用bootstrap时,请使用列:
<div class="transitions-enabled" id="post">
<div class="row">
<%- @posts.each do |post|%>
<div class="col-md-4 post">
<!-- post content -->
</div>
<% end %>
</div>
</div>
您将找到不同的列类型here。
为您的帖子提供.col-md-4
课程将使其显示为三个对齐:
4-4-4
4-4-4
将每一行合计为12。
您还应该删除css中的float
样式,并将.row
移到迭代之外,因为bootstrap会为您处理。
答案 2 :(得分:0)
您应该尝试将其添加到 panel-body 。
还可以在http://masonry.desandro.com/查看(不是现在,但将来当你使用3个以上的块时)连续平铺的div。