Ruby onRails-足場

Railsアプリケーション、特にデータベース内のデータへの単純なインターフェイスを主に提供するアプリケーションを開発しているときは、scaffoldメソッドを使用すると便利なことがよくあります。

足場は、安価なデモスリル以上のものを提供します。ここにいくつかの利点があります-

  • フィードバックのためにユーザーの前でコードをすばやく取得できます。

  • あなたはより速い成功によって動機づけられます。

  • 生成されたコードを見ると、Railsがどのように機能するかを学ぶことができます。

  • 足場を基盤として使用して、開発をすぐに開始できます。

足場の例

足場を理解するために、というデータベースを作成しましょう。cookbook と呼ばれるテーブル recipes

空のRailsWebアプリケーションの作成

コマンドウィンドウを開き、これを作成する場所に移動します cookbookウェブアプリケーション。したがって、次のコマンドを実行して、完全なディレクトリ構造を作成します。

tp> rails new cookbook

データベースの設定

データベースを作成する方法は次のとおりです-

mysql> create database cookbook;
Query OK, 1 row affected (0.01 sec)

mysql> grant all privileges on cookbook.*
to 'root'@'localhost' identified by 'password';
Query OK, 0 rows affected (0.00 sec)

mysql> FLUSH PRIVILEGES;
Query OK, 0 rows affected (0.00 sec)

Railsにデータベースの検索方法を指示するには、構成ファイルcookbook \ config \ database.ymlを編集し、データベース名をcookbookに変更します。パスワードは空のままにします。終了すると、次のようになります-

development:
   adapter: mysql
   database: cookbook
   username: root
   password: [password]
   host: localhost
	
test:
   adapter: mysql
   database: cookbook
   username: root
   password: [password]
   host: localhost
	
production:
   adapter: mysql
   database: cookbook
   username: root
   password: [password]
   host: localhost

Railsを使用すると、さまざまなデータベースを使用して、開発モード、テストモード、または本番モードで実行できます。このアプリケーションは、それぞれに同じデータベースを使用します。

生成されたスキャフォールドコード

スキャフォールドアクションを使用すると、Railsは必要なすべてのコードを動的に生成します。スキャフォールドをスクリプトとして実行することで、すべてのコードをディスクに書き込んで、そこで調査し、要件に合わせて調整を開始できます。

それでは、もう一度、scaffoldヘルパースクリプトを使用してScaffoldコードを手動で生成することから始めましょう-

cookbook> rails generate scaffold recipe

以下に示すように自動ファイルを生成します-

コントローラー

コントローラの背後にあるコードを見てみましょう。このコードはによって生成されますscaffold発生器。app / controllers / recipes_controller.rbを開くと、次のようなものが見つかります-

class RecipesController < ApplicationController
   before_action :set_recipe, only: [:show, :edit, :update, :destroy]
   
   # GET /recipes
   # GET /recipes.json
   def index
      @recipes = Recipe.all
   end
   
   # GET /recipes/1
   # GET /recipes/1.json
   def show
   end
   
   # GET /recipes/new
   def new
      @recipe = Recipe.new
   end
   
   # GET /recipes/1/edit
   def edit
   end
   
   # POST /recipes
   # POST /recipes.json
   def create
      @recipe = Recipe.new(recipe_params)
      
      respond_to do |format|
         if @recipe.save
            format.html { redirect_to @recipe, notice: 'Recipe was successfully created.' }
            format.json { render :show, status: :created, location: @recipe }
         else
            format.html { render :new }
            format.json { render json: @recipe.errors, status: :unprocessable_entity }
         end
      end
      
   end
   
   # PATCH/PUT /recipes/1
   # PATCH/PUT /recipes/1.json
   def update
      respond_to do |format|
         if @recipe.update(recipe_params)
            format.html { redirect_to @recipe, notice: 'Recipe was successfully updated.' }
            format.json { render :show, status: :ok, location: @recipe }
         else
            format.html { render :edit }
            format.json { render json: @recipe.errors, status: :unprocessable_entity }
         end
      end
      
   end
   
   # DELETE /recipes/1
   # DELETE /recipes/1.json
   def destroy
      @recipe.destroy
         respond_to do |format|
         format.html { redirect_to recipes_url, notice: 'Recipe was successfully destroyed.' }
         format.json { head :no_content }
      end
   end
   
   private
   
   # Use callbacks to share common setup or constraints between actions.
   def set_recipe
      @recipe = Recipe.find(params[:id])
   end
   
   # Never trust parameters from the scary internet, only allow the white list through.
   def recipe_params
      params.require(:recipe).permit(:tittle, :instructions)
   end
end

Railsアプリケーションのユーザーがアクションを選択すると、たとえば「Show」-コントローラーは適切なセクションの任意のコードを実行します-「defshow」-そしてデフォルトで同じ名前のテンプレートをレンダリングします-「show.html」。 erb」。このデフォルトの動作は上書きできます。

コントローラは、find、find_all、new、save、update_attributes、destroyなどのActiveRecordメソッドを使用して、データベーステーブルとの間でデータを移動します。SQLステートメントを記述する必要はないことに注意してください。railsが自動的に処理します。

この1行のコードで、データベーステーブルに命を吹き込みます。それはあなたのデータへのシンプルなインターフェースと-の方法を提供します

  • 新しいエントリの作成
  • 現在のエントリの編集
  • 現在のエントリの表示
  • 現在のエントリを破棄する

エントリを作成または編集するとき、scaffoldはフォームの生成や処理などのすべてのハードワークを実行し、さらに巧妙なフォームの生成を提供し、次のタイプの入力をサポートします-

  • 単純なテキスト文字列
  • テキスト領域(またはテキストの大きなブロック)
  • 日付セレクター
  • 日時セレクター

Rails Migrationsを使用して、テーブルを作成および保守できます。

rake db:migrate RAILS_ENV=development

次に、クックブックディレクトリに移動し、次のコマンドを使用してWebサーバーを実行します-

cookbook> rails server

次に、ブラウザを開いてに移動します http://127.0.0.1:3000/recipe/new.これにより、レシピテーブルに新しいエントリを作成するための画面が表示されます。スクリーンショットを以下に示します-

を押すと Create ボタンをクリックして新しいレシピを作成すると、レコードがレシピテーブルに追加され、次の結果が表示されます-

レコードを編集、表示、および破棄するオプションが表示されます。したがって、これらのオプションを試してみてください。

URL http://127.0.0.1:3000/recipe/listを使用して、レシピテーブルで使用可能なすべてのレシピを一覧表示することもできます。

モデルの強化

Railsは無料で多くのエラー処理を提供します。これを理解するには、空のレシピモデルにいくつかの検証ルールを追加します-

app / models / recipe.rbを次のように変更してから、アプリケーションをテストします-

class Recipe < ActiveRecord::Base
   validates_length_of :title, :within => 1..20
   validates_uniqueness_of :title, :message => "already exists"
end

これらのエントリは自動チェックを提供します。

  • validates_length_of −フィールドは空白ではなく、長すぎません。

  • validates_uniqueness_of−重複する値がトラップされます。デフォルトのRailsエラーメッセージの代わりに、ここにカスタムメッセージを表示しました。

足場を作成する別の方法

上記のようにアプリケーションを作成し、 The Generated Scaffold Code 以下に示すように

rails g scaffold Recipe tittle:string instructions:text

上記のコードは、画像の下に示すように、タイトルと命令列を含むsqlite3を使用して、データベースを含む自動ファイルを生成します。

以下の構文を使用してデータベースを移行する必要があります。

$ rake db:migrate RAILS_ENV=development

最後に、次のコマンドラインを使用してアプリケーションを実行します-

rails server

上記の出力画像のような結果が生成されます。

ビュー

すべてのビューと対応するすべてのコントローラーメソッドは、によって作成されます scaffold コマンドとそれらはapp / views / recipesディレクトリで利用可能です。

足場はどのように異なりますか?

前の章を読んだ場合は、データの一覧表示、表示、削除、作成などのメソッドを作成したことを確認したはずですが、scaffoldはその仕事を自動的に行います。