Ruby onRails-コントローラー

Railsコントローラーは、アプリケーションの論理的な中心です。これは、ユーザー、ビュー、およびモデル間の相互作用を調整します。コントローラーは、多くの重要な補助サービスの拠点でもあります。

  • 外部リクエストを内部アクションにルーティングする役割を果たします。人に優しいURLを非常にうまく処理します。

  • キャッシュを管理し、アプリケーションのパフォーマンスを桁違いに向上させることができます。

  • ヘルパーモジュールを管理します。ヘルパーモジュールは、コードをまとめることなくビューテンプレートの機能を拡張します。

  • セッションを管理し、ユーザーにアプリケーションとの継続的な対話の印象を与えます。

コントローラを作成するプロセスは非常に簡単で、モデルの作成にすでに使用したプロセスと似ています。ここでコントローラーを1つだけ作成します-

library\> rails generate controller Book

Bookを大文字にして、単数形を使用していることに注意してください。これは、コントローラーを作成するたびに従う必要のあるRailsパラダイムです。

このコマンドはいくつかのタスクを実行しますが、そのうち以下がここに関連しています-

  • と呼ばれるファイルを作成します app/controllers/book_controller.rb

book_controller.rbを見ると、次のようになっています。

class BookController < ApplicationController
end

コントローラクラスは、コントローラフォルダ内の他のファイルであるApplicationControllerから継承します。application.rb

ApplicationControllerには、すべてのあなたのコントローラで実行できるコードが含まれており、それがRailsのから継承ActionController ::基本クラス。

現時点ではApplicationControllerについて心配する必要はないので、でいくつかのメソッドスタブを定義しましょう。book_controller.rb。要件に基づいて、このファイルで任意の数の関数を定義できます。

次のようにファイルを変更し、変更を保存します。これらのメソッドにどのような名前を付けるかはあなた次第ですが、関連する名前を付ける方がよいことに注意してください。

class BookController < ApplicationController
   def list
   end
   
   def show
   end
   
   def new
   end
   
   def create
   end
   
   def edit
   end
   
   def update
   end
   
   def delete
   end
   
end

それでは、すべてのメソッドを1つずつ実装してみましょう。

リストメソッドの実装

listメソッドは、データベース内のすべての本のリストを提供します。この機能は、次のコード行によって実現されます。book_controller.rbファイルの次の行を編集します。

def list
   @books = Book.all
end

listメソッドの@ books = Book.all行は、Railsにbooksテーブルを検索し、見つかった各行を@booksインスタンスオブジェクトに格納するように指示します。

showメソッドの実装

showメソッドは、1冊の本の詳細のみを表示します。この機能は、次のコード行によって実現されます。

def show
   @book = Book.find(params[:id])
end

showメソッドの@ book = Book.find(params [:id])行は、params [:id]で定義されたIDを持つ本のみを検索するようにRailsに指示します。

paramsオブジェクトは、メソッド呼び出し間で値を渡すことができるコンテナです。たとえば、listメソッドで呼び出されたページを表示しているときに、特定の本のリンクをクリックすると、その本のIDがparamsオブジェクトを介して渡され、showが特定の本を見つけることができます。

新しいメソッドの実装

新しいメソッドは、新しいオブジェクトを作成することをRailsに通知します。したがって、このメソッドに次のコードを追加するだけです。

def new
   @book = Book.new
   @subjects = Subject.all
end

上記のメソッドは、ユーザー入力を取得するためにユーザーにページを表示するときに呼び出されます。ここで、2行目はデータベースからすべてのサブジェクトを取得し、@ subjectsという配列に配置します。

createメソッドの実装

HTMLフォームを使用してユーザー入力を取得したら、データベースにレコードを作成します。これを実現するには、book_controller.rbのcreateメソッドを次のように編集します。

def create
   @book = Book.new(book_params)
	
   if @book.save
      redirect_to :action => 'list'
   else
      @subjects = Subject.all
      render :action => 'new'
   end
   
end

def book_params
   params.require(:books).permit(:title, :price, :subject_id, :description)
end

最初の行は、ユーザーが送信したデータから構築されたBookオブジェクトを保持する@bookという新しいインスタンス変数を作成します。ザ・book_params メソッドは、オブジェクトからすべてのフィールドを収集するために使用されます :books。データは、paramsオブジェクトを使用して作成するために新しいメソッドから渡されました。

次の行は、ユーザーをにリダイレクトする条件ステートメントです。 listオブジェクトがデータベースに正しく保存される場合のメソッド。保存されない場合、ユーザーは新しいメソッドに戻されます。redirect_toメソッドは、Webページでメタリフレッシュを実行するのと似ています。ユーザーの操作なしで、宛先に自動的に転送します。

次に、@ subject = Subject.allは、データが正常に保存されず、新しいオプションの場合と同様の場合に必要です。

編集メソッドの実装

editメソッドはshowメソッドとほぼ同じように見えます。どちらのメソッドも、IDに基づいて単一のオブジェクトを取得し、それをページに表示するために使用されます。唯一の違いは、showメソッドが編集できないことです。

def edit
   @book = Book.find(params[:id])
   @subjects = Subject.all
end

このメソッドは、ユーザーが変更するデータを画面に表示するために呼び出されます。2行目は、データベースからすべてのサブジェクトを取得し、それらを@subjectsという配列に配置します。

更新メソッドの実装

このメソッドは、ユーザーがデータを変更し、データベースへの変更を更新したいときに、editメソッドの後に呼び出されます。updateメソッドはcreateメソッドに似ており、データベース内の既存の書籍を更新するために使用されます。

def update
   @book = Book.find(params[:id])
	
   if @book.update_attributes(book_param)
      redirect_to :action => 'show', :id => @book
   else
      @subjects = Subject.all
      render :action => 'edit'
   end
   
end

def book_param
   params.require(:book).permit(:title, :price, :subject_id, :description)
end

update_attributesメソッドは、createで使用されるsaveメソッドに似ていますが、データベースに新しい行を作成する代わりに、既存の行の属性を上書きします。

次に、@ subject = Subject.all行が必要ですが、データが正常に保存されない場合は、編集オプションと同様になります。

削除メソッドの実装

データベースからレコードを削除する場合は、この方法を使用します。このメソッドを次のように実装します。

def delete
   Book.find(params[:id]).destroy
   redirect_to :action => 'list'
end

最初の行は、paramsオブジェクトを介して渡されたパラメーターに基づいて分類されたものを検索し、destroyメソッドを使用してそれを削除します。2行目は、redirect_to呼び出しを使用して、ユーザーをlistメソッドにリダイレクトします。

主題を表示するための追加の方法

特定の主題に基づいてすべての本を閲覧する機能をユーザーに提供するとします。したがって、book_controller.rb内にメソッドを作成して、すべての件名を表示できます。メソッド名がshow_subjects

def show_subjects
   @subject = Subject.find(params[:id])
end

最後にあなたの book_controller.rb ファイルは次のようになります-

class BooksController < ApplicationController

   def list
      @books = Book.all
   end

   def show
      @book = Book.find(params[:id])
   end
  
   def new
      @book = Book.new
      @subjects = Subject.all
   end

   def book_params
      params.require(:books).permit(:title, :price, :subject_id, :description)
   end

   def create
      @book = Book.new(book_params)

      if @book.save
         redirect_to :action => 'list'
      else
         @subjects = Subject.all
         render :action => 'new'
      end
   end
   
   def edit
      @book = Book.find(params[:id])
      @subjects = Subject.all
   end
   
   def book_param
      params.require(:book).permit(:title, :price, :subject_id, :description)
   end
   
   def update
      @book = Book.find(params[:id])
      
      if @book.update_attributes(book_param)
         redirect_to :action => 'show', :id => @book
      else
         @subjects = Subject.all
         render :action => 'edit'
      end
   end
   
   def delete
      Book.find(params[:id]).destroy
      redirect_to :action => 'list'
   end
   
   def show_subjects
      @subject = Subject.find(params[:id])
   end

end

次に、コントローラーファイルを保存します。

次は何ですか?

バックエンドで機能するほぼすべてのメソッドを作成しました。次に、アクションのルート(URL)を定義します。