Rails:如何实现帖子视图的数量?

时间:2012-11-11 01:33:27

标签: ruby-on-rails ruby database post views

有什么问题?:

我正在创建一个通用博客,并致力于创建基本功能。 问题是视图(有多少人看过特定的帖子)没有正确显示。

现状:

此时我有两个控制器/模型:发布和评论。我将为您提供我的架构,以帮助您更好地了解情况。

create_table "comments", :force => true do |t|
t.string   "name"
t.text     "body"
t.integer  "like"
t.integer  "hate"
t.integer  "post_id"
t.datetime "created_at", :null => false
t.datetime "updated_at", :null => false
end

add_index "comments", ["post_id"], :name => "index_comments_on_post_id"

create_table "posts", :force => true do |t|
t.string   "name"
t.text     "content"
t.integer  "view"
t.integer  "like"
t.integer  "hate"
t.datetime "created_at", :null => false
t.datetime "updated_at", :null => false
end

我做了什么: 在Post Controller中,我试图通过在有人创建帖子时将其设置为0来初始化视图。

# POST /posts
# POST /posts.json
def create
@post = Post.new(params[:post])
@view = @post.view
@view = 0

respond_to do |format|
  if @post.save
    format.html { redirect_to posts_path, notice: 'success.' }
    format.json { render json: @post, status: :created, location: @post }
    @view = @post.view
    @view = 0
  else
    format.html { render action: "new" }
    format.json { render json: @post.errors, status: :unprocessable_entity }
  end

end

该帖子应该能够显示其观看次数。所以在帖子的show.html.erb文件中,我也添加了下面的部分。     <p> <b>views:</b> <%= @post.view %> </p>

如何无效 根本没有显示视图的数量。我检查了数据库,即使我试图在用户添加帖子时将其初始化为0,列也是空白的。我猜我尝试访问“视图”变量的方式有问题吗?通过这样做来访问它是不对的
@view = @ post.view?

我知道我必须考虑一个已经看过帖子的用户是否重新访问,但我还没有到那里,直到我确切知道如何访问视图变量/初始化/增加它。

我非常感谢您的帮助!

-Max

1 个答案:

答案 0 :(得分:2)

要将Post的视图属性初始化为零,之前调用@ post.save(作为if语句的副作用):

@post.view = 0

然后在您的控制器动作中呈现帖子,您需要将帖子的视图属性更新为1.如果多个人在数据库读取和写入之间同时访问页面,则会出现问题,但它至少会让您朝着正确的方向前进。

在保存数据库之后,@view在此处为值分配的任务都没有完成。