3

假设我有一个带有两个父模型的子模型:

Event has_many tickets

Person has_many tickets

Ticket belongs_to Event
Ticket belongs_to Person

路由被映射,因此 Ticket 总是嵌套在 Event 或 Person 中:

resource :people do
  resources :tickets
end

resources :events do
  resources :tickets
end

如何按父资源限定我的 ticket_Controller CRUD 操作?

现在我正在测试参数并使用条件语句:

class TicketController

  before_filter :get_person
  before_filter :get_event

  def index
    if @person do
      ...
    elsif @event do
      ...
    end
    respond_to
      ...
    end
  end

对于每一个动作,这似乎有点乏味。有没有更多的 rails-y DRY 方法来做到这一点?

4

2 回答 2

3

最干的将是使用inherited_resources:

class TicketsController < InheritedResources::Base
  belongs_to :event, :person, :polymorphic => true
end

轰……完成。但是,如果您出于某种原因不能使用inherited_resources,而不是get_person或者get_event您可以设置一个过滤器来get_parent喜欢这样:

class TicketsController < ActionController::Base
  before_filter :get_parent

  def get_parent
    if params[:person_id]
      @parent = Person.find(params[:person_id])
      @template_prefix = 'people/tickets/'
    elsif params[:event_id]
      @parent = Event.find(params[:event_id])
      @template_prefix = 'events/tickets/'
    else
      # handle this case however is appropriate to your application...
    end
  end

  # Then you can set up your index to be more generic
  def index
    @tickets = @parent.tickets
    render :template => @template_prefix + 'index'
  end
end

编辑:我在上面添加了@template_prefix 来解决您在评论中提到的模板问题。

于 2010-09-06T17:55:41.813 回答
0

你可以这样做:

class TicketController

  before_filter :get_object

  def index

  end

  private

  def get_object
    type = params['event_id'] ? 'event' : 'person'
    value = type.classify.constantize.find(params[:"#{type}_id"])
    name = '@' + type
    instance_variable_set(name , value)
  end

end

有很多方法可以改进上面的代码。

您还可以编写如下路线:

resources :people, :has_many => :tickets

resources :events, :has_many => :tickets
于 2010-09-06T17:53:01.190 回答