冻结Ruby中的随机数

时间:2012-11-02 23:56:57

标签: ruby-on-rails ruby ajax ruby-on-rails-3 random

我正在尝试构建一些东西,它会从Ruby中的列表中随机选择两个对象(使用Rails),然后对这些对象执行基本操作。我当前的设置涉及在开始时随机选择数字 - 使用这些数字从数据库中获取对象,然后将这些对象呈现为索引。但是,现在我正在尝试使用AJAX编辑这些对象,我遇到了问题。

当我点击链接时,重新计算的随机数会导致我的AJAX功能不起作用。

我已经包含了(我相信的)以下所有相关代码,但如果您需要查看其他任何内容,请告知我们。我希望得到旧动物的头衔和(最好是他们之前的评级和)他们的新评级出现在页面底部。

谢谢,

马特

controllers/static_pages.rb

class StaticPagesController < ApplicationController
respond_to :html, :js
before_filter :pickanimals

def pickanimals
    @allAnimals = Animal.all
    @random_no = rand(@allAnimals.length)
    @animal = @allAnimals[@random_no]
    @allAnimals.delete_at(@random_no)
    @newRandom = rand(@allAnimals.length)
    @animal2 = @allAnimals[@newRandom]
end

  def index
    respond_to do |format|
        format.html
        format.js
    end
end

  def help
  end

  def about
  end

  def contact
  end

def league
end

def voting
    @votedAnimal = Animal.find(params[:id])
    if @votedAnimal == @animal
        @animal.rating += 1
        @animal2.rating -= 1
    else
        @animal.rating -= 1
        @animal2.rating += 1    
    end
    Animal.transaction do
        @animal.save!
        @animal2.save!
    end
    respond_to do |format|
        format.html { redirect_to root_path }
        format.js  
    end
end
end

app/views/static_pages/index.html.erb

<div class="center hero-unit">
<h1>Animal Attack</h1>
<p> Who will win when nature collides? </p>
<div class="animalcontainerright">
<h2> <%= @animal.name %> </h2> 
<%= link_to image_tag(@animal.attachment.url(:large)), voting_path(@animal.id), :remote => true, :confirm => "Rating:  "+@animal.rating.to_s  %>
</div>
<div class="animalcontainerleft">
<h2> <%= @animal2.name %> </h2>
<%= link_to image_tag(@animal2.attachment.url(:large)), voting_path(@animal2.id), :remote => true, :confirm => "Rating:  "+@animal2.rating.to_s  %>
</div>
<div id="animalfacts"></div>

routes.rb

AnimalAttack::Application.routes.draw do

resources :animals

root to: 'static_pages#index'
match '/help' => 'static_pages#help'
match '/about' => 'static_pages#about'
match '/contact' => 'static_pages#contact'
match '/league' => 'static_pages#league'
match '/voting/:id' => 'static_pages#voting'

end

rake routes

    animals GET    /animals(.:format)          animals#index
        POST   /animals(.:format)          animals#create
 new_animal GET    /animals/new(.:format)      animals#new
edit_animal GET    /animals/:id/edit(.:format) animals#edit
 animal GET    /animals/:id(.:format)      animals#show
        PUT    /animals/:id(.:format)      animals#update
        DELETE /animals/:id(.:format)      animals#destroy
   root        /                           static_pages#index
   help        /help(.:format)             static_pages#help
  about        /about(.:format)            static_pages#about
contact        /contact(.:format)          static_pages#contact
 league        /league(.:format)           static_pages#league
               /animals(.:format)          animals#new
               /voting/:id(.:format)       static_pages#voting

1 个答案:

答案 0 :(得分:8)

我猜你的@animal正在重新分配:before_filter。除非您另外说明,否则它将在所有操作之前执行(从而在每个控制器操作之前重新分配@animal)。您可能希望将其限制为仅需要新重新生成的随机数的方法。例如:

before_filter :pickanimals, :only => :index

另外。你知道Array#sample吗?它是从数组中选择随机元素的内置方法。您可能会发现它在这里很有用:

@animal, @animal2 = @allAnimals.sample(2)

<强>进行追加

依赖于控制器中的实例变量,这是在函数之间传递信息的一种非常脆弱的方式。如果您的控制器需要知道两个模型的id以根据用户选择在每个模型上增加或减少计数器,为什么不使用表单将这两个id发送到此控制器操作?到目前为止,您只需要两个字段:chosen_animal_idreject_animal_id