0

これはかなり基本的な質問ですが、アプリケーションに組み込むのに苦労しています。SOに関する他の同様の質問を見てきましたが、それらはすべて連絡先ページを別のページとして使用しています。

Railsアプリのフロントエンドがあります。これは、視差スクロールにstellar.jsを使用する小さな公開サイトです。

ページの最後に「お問い合わせ」フォームが欲しいのですが、

NoMethodError in Welcome#index undefined method `model_name' for NilClass:Class

関連するファイルは次のとおりです。

ルート.rb

TestApp::Application.routes.draw do
   get "welcome/index"
   root :to => 'welcome#index'
   match 'contact' => 'contact#new', :as => 'contact', :via => :get
   match 'contact' => 'contact#create', :as => 'contact', :via => :post

app / views / welcome / index.html.erb

<%= render "contact" %>

ページapp/views / welcome/_contact.html.erbの連絡先セクションの部分

 <%= form_for @message, :url => contact_path do |form| %>
  <fieldset class="fields">
     <div class="field">
        <%= form.label :name %>
        <%= form.text_field :name %>
     </div>

     <div class="field">
        <%= form.label :email %>
        <%= form.text_field :email %>
     </div>
     <div class="field">
        <%= form.label :subject %>
        <%= form.text_field :subject %>
     </div>

     <div class="field">
        <%= form.label :body %>
        <%= form.text_area :body %>
     </div>
  </fieldset>

  <fieldset class="actions">
     <%= form.submit "Send" %>
  </fieldset>
  <% end %>

app / controllers / contact_controller.rb

class ContactController < ApplicationController
   def new
      @message = Message.new
   end

   def create
      @message = Message.new(params[:message])

      if @message.valid?
         NotificationsMailer.new_message(@message).deliver
         redirect_to(root_path, :notice => "Message was successfully sent.")
      else
         flash.now.alert = "Please fill all fields."
         render :new
      end
   end
end

message.rb

class Message

   include ActiveModel::Validations
   include ActiveModel::Conversion
   extend ActiveModel::Naming

   attr_accessor :name, :email, :subject, :body

   validates :name, :email, :subject, :body, :presence => true
   validates :email, :format => { :with => %r{.+@.+\..+} }, :allow_blank => true

   def initialize(attributes = {})
     attributes.each do |name, value|
         send("#{name}=", value)
     end 
   end

   def persisted?
      false
   end
end

問題は、welcome#indexビューでこのフォームを正しく機能させるために何をする必要があるかということです。

4

2 に答える 2

2

存在する必要がある@message = Message.newすべてのアクションで定義する必要があり@messageます。

つまり、これが必要ですWelcomeController

def index
  @message = Message.new
end

ショートカットは、設定されていない場合に備えてパーシャルの先頭に追加することです:

<% @message ||= Message.new %>

(ただし、ビュー内でモデルへの呼び出しを混在させることが自分のスタイルであるかどうかを判断する必要があります。一部の開発者はこれに問題を抱えていませんが、一部の開発者は問題を抱えています。)

于 2013-02-08T03:39:06.973 に答える
1

次のように変更できます。

ルート内:

削除する:

match 'contact' => 'contact#new', :as => 'contact', :via => :get
match 'contact' => 'contact#create', :as => 'contact', :via => :post

追加:

resources :contact   # It will add 7 default REST routes and standard practice model name should be plural if you created your model with singular then keep it singular 

_contact.html.erb部分的にform pathする必要がありますnew_contact_path

<%= form_for Message.new, :url => contact_path do |form| %>

クラスMessageは継承する必要がありますActiveRecord::Base

class Message < ActiveRecord::Base

end 

実際にはcreate、他の部分は次のようになります。

if @message.valid?
     NotificationsMailer.new_message(@message).deliver
     redirect_to(root_path, :notice => "Message was successfully sent.")
else
     flash.now.alert = "Please fill all fields."
     render :template => "welcome/index"
end 
于 2013-02-08T03:31:13.403 に答える