现在有了 issue 也就是活动信息这个东东,后面就开始对他 Create Read Update Delete 了。这一集只是开始,瞄准读取展示 issue 还有删除 issue 。 关于 CRUD 比较详细的解释,参考 http://railsforzombies.org/levels/1

添加 content 到 issue

首先运行一下 migration

rails g migration AddContentToIssues content:text
rake db:migrate

下面打开 rails console 插入一下数据

i = Issue.find(1)
i.content = "Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod"
i.save
i = Issue.find(2)
...

添加路由

get '/issues/:id' => "issues#show"

到 _issue_list.html.erb 中添加指向 issues#show 页面的链接

- <%= link_to i.title, "#" %>
+ <%= link_to i.title, "/issues/#{i.id}" %>

打开 welcome 页面,点击链接之前想想,是不是应该报错了?想不出来报啥错就证明你前面没好好听,哈。

uninitialized constant IssuesController

前面是手动创建 controller,熟悉一点之后了,现在可以用 rails generator 来自动生成

用 generator 的时候避免生成太多用不到的文件,到 application.rb 中添加

config.generators do |g|
    g.assets false
    g.helper false
    g.test_framework false
end

然后运行

rails g controller issues show # 注意是 issues 不是 issue

停一停,看一看,都生出了那些文件,routes.rb 中这句是没用的,先删掉。不仅 issues_controller.rb 有了,还生成了 show action 对应的模板,还真是省事不少。

下面就是要填充 views/issues/show.html.erb 中的内容了。先得到 issues_controller.rb 中

def show
+  render plain: params[:id].inspect
end

这样敲链接 http://meetup.dev:3000/issues/1 页面上就显示 1,敲 http://meetup.dev:3000/issues/2 的时候页面就显示 2 那这个 params[:id] 的作用也就清楚了。当然这只是处于调试目的,所以这一行可以删掉

def show
  @issue = Issue.find(params[:id])
end

这样 show 页面中再添加合适的 erb 语句就可以展示清楚了。issues/show.html.erb 中放入

<div class="issue-heading">
  <div class="container">
    <%= @issue.title %>
  </div>
</div>
<div class="container">
  <div class="replies">
    <article class="reply clearfix">
      <div class="avatar">
        <img src="http://gravatar.com/avatar/a92785d8d68f1d1d83b008574f8b5dba.png?s=512&amp;d=retr" alt="" class="image-circle">
      </div>
      <div class="body">
        <div class="heading">
          <h5 class="name"><a href="#">happypeter</a></h5>
        </div>
        <%= @issue.content %>
      </div>
    </article>
  </div>
</div>

再来创建一个对应的 app/assets/stylesheets/sections/issue_show.css.scss

.issue-heading {
  border-bottom: 1px solid #ddd;
  padding-bottom: 30px;
  padding-top: 30px;
  margin-top: 0;
  margin-bottom: 35px;
  background: #7EB6AD;
  color: #fff;
  font-size: 2em;
}

.reply {
  position: relative;
  overflow: hidden;
  margin-bottom: 30px;
  width: 91%;
  .heading {
    margin-bottom: 5px;
    .name {
      font-size: 18px;
      display: inline;
      font-weight: normal;
    }
  }
  .body {
    padding: 15px;
    border-radius: 5px;
    position: relative;
    overflow: visible;
    float: left;
    width: 87%;
    border: 1px solid #ddd;
    line-height: 26px;
    &::before {
      content: "";
      display: block;
      position: absolute;
      top: 21px;
      left: -6px;
      width: 10px;
      height: 10px;
      background: #fff;
      border-left: 1px solid #cad5e0;
      border-top: 1px solid #cad5e0;
      -moz-transform: rotate(-45deg);
      -webkit-transform: rotate(-45deg);
    }
  }
  .avatar {
    float: left;
    margin-right: 29px;
    position: relative;
    overflow: visible;
    text-align: center;
    .image-circle {
      width: 75px;
      border-radius: 50%;
    }
  }
}

但是再来稍微优化一些代码。到 _issue_list.html.erb

- <%= link_to i.title, "/issues/#{i.id}" %>
+ <%= link_to i.title, issue_path(i) %>

这样当然会报错,但是 rails 提供了给路由起名字的机制,叫 “named route”,需要做的就是到 routes.rb 中

- get '/issues/:id' => "issues#show"
+ get '/issues/:id' => "issues#show", :as => "issue"

现在就行了。

删除一个资源

现在就来看如果删除一个资源。还是从 view 中的链接开始写。在 issues/show.html.erb 中添加一个删除的链接。

<%= link_to 'Destroy', issue_path(@issue), method: :delete, data: { confirm: 'Are you sure?' }, class: "btn btn-primary" %>

到 app/assets/stylesheets/shared/common.css 给文件添加 .scss 后缀,并且添加一些按钮样式进来。

.btn-primary {
  color: white;
  background: #c0865e;
  border-color: #b9784c;
  &:hover {
    background-color: #b9784c;
    border-color: #845534;
  }
}
.btn {
  display: inline-block;
  padding: 6px 12px;
  margin-bottom: 0;
  font-size: 14px;
  font-weight: normal;
  line-height: 1.428571429;
  text-align: center;
  vertical-align: middle;
  cursor: pointer;
  border: 1px solid transparent;
  border-radius: 4px;
  white-space: nowrap;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  -o-user-select: none;
  user-select: none;
}

issue_show.css.scss 中也要有一点修改

.issue-heading {
...
+ a {
+   margin-left: 30px;
+ }
}

样式弄好了。对应的 routes.rb 中要添加

delete 'issues/:id' => 'issues#destroy'

再到 issues_controller.rb 添加

def destroy
  issue = Issue.find(params[:id])
  issue.destroy
  redirect_to :root
end