如何用rails显示内联?

时间:2016-06-21 22:39:23

标签: html css ruby-on-rails ruby

我想知道如何显示我的帖子“内联” 我开始使用CSS,我不知道在哪里放置代码显示:内联在我的css表上。我试试post,main_content,body,但它不起作用。你能解释一下如何做到这一点,我跟随了很多tuto,结果对我来说从来都不一样,所以我不明白该怎么做。

我的实际帖子显示: Actual display

我的代码: 索引帖子视图:

<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;
}

3 个答案:

答案 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。