Ruby on Rails - İskele

Rails uygulamaları geliştirirken, özellikle size bir veritabanındaki verilere basit bir arayüz sağlayanlar geliştirirken, genellikle iskele yöntemini kullanmak yararlı olabilir.

İskele, ucuz demo heyecandan daha fazlasını sağlar. İşte bazı avantajlar -

  • Geri bildirim almak için kullanıcılarınızın önüne hızlı bir şekilde kod alabilirsiniz.

  • Daha hızlı başarı ile motive oluyorsunuz.

  • Oluşturulan koda bakarak Rails'in nasıl çalıştığını öğrenebilirsiniz.

  • Geliştirmenize hızlı bir başlangıç ​​yapmak için iskeleyi temel olarak kullanabilirsiniz.

İskele Örneği

İskeleyi anlamak için , adında bir veritabanı oluşturalımcookbook ve bir masa deniyor recipes.

Boş Rails Web Uygulaması Oluşturma

Bir komut penceresi açın ve bunu oluşturmak istediğiniz yere gidin cookbookweb uygulaması. Bu nedenle, tam bir dizin yapısı oluşturmak için aşağıdaki komutu çalıştırın.

tp> rails new cookbook

Veritabanını Kurmak

İşte bir veritabanı oluşturmanın yolu -

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'e veritabanını nasıl bulacağını öğretmek için, yemek kitabı \ config \ veritabanı.yml yapılandırma dosyasını düzenleyin ve veritabanı adını yemek kitabı olarak değiştirin. Parolayı boş bırakın. Bitirdiğinizde aşağıdaki gibi görünmelidir -

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, farklı veritabanları kullanarak geliştirme modunda, test modunda veya üretim modunda çalışmanıza olanak tanır. Bu uygulama her biri için aynı veritabanını kullanır.

Oluşturulan İskele Kodu

İskele eylemi ile Rails, ihtiyaç duyduğu tüm kodu dinamik olarak üretir. Scaffold'u komut dosyası olarak çalıştırarak , diske yazılan tüm kodu inceleyebilir ve ardından gereksinimlerimize göre uyarlamaya başlayabiliriz.

Şimdi, scaffold yardımcı komut dosyasını kullanarak Scaffold kodunu manuel olarak oluşturmaya bir kez daha başlayalım -

cookbook> rails generate scaffold recipe

Aşağıda gösterildiği gibi otomatik dosyalar oluşturur -

Kontrol eden, denetleyici

Denetleyicinin arkasındaki koda bakalım. Bu kod,scaffoldjeneratör. App / controllers / recipe_controller.rb dosyasını açarsanız, aşağıdaki gibi bir şey bulacaksınız -

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

Bir Rails uygulamasının kullanıcısı bir eylemi seçtiğinde, örneğin "Göster" - denetleyici uygun bölümde herhangi bir kodu çalıştırır - "def show" - ve ardından varsayılan olarak aynı ada sahip bir şablon - "show.html" oluşturur. erb ". Bu varsayılan davranışın üzerine yazılabilir.

Denetleyici, verileri veritabanı tablolarına / tablolarından taşımak için find, find_all, new, save, update_attributes ve destroy gibi ActiveRecord yöntemlerini kullanır . Herhangi bir SQL ifadesi yazmanız gerekmediğini unutmayın, raylar bunu otomatik olarak halleder.

Bu tek satırlık kod veritabanı tablosunu hayata geçirecektir. Verilerinize basit bir arayüz ve şu yolları sağlayacaktır:

  • Yeni girişler oluşturma
  • Mevcut girişleri düzenleme
  • Mevcut girişleri görüntüleme
  • Mevcut girişleri yok etmek

Bir giriş oluştururken veya düzenlerken, scaffold sizin için form oluşturma ve işleme gibi tüm zor işleri yapacak ve hatta aşağıdaki giriş türlerini destekleyerek akıllı form oluşturma sağlayacaktır -

  • Basit metin dizeleri
  • Metin alanları (veya büyük metin blokları)
  • Tarih seçiciler
  • Tarih-saat seçicileri

Tablolar oluşturmak ve sürdürmek için Rails Migrations'ı kullanabilirsiniz.

rake db:migrate RAILS_ENV=development

Şimdi, yemek kitabı dizinine gidin ve aşağıdaki komutu kullanarak Web Sunucusunu çalıştırın -

cookbook> rails server

Şimdi bir tarayıcı açın ve şuraya gidin: http://127.0.0.1:3000/recipe/new.Bu size tarifler tablosunda yeni girişler oluşturmanız için bir ekran sağlayacaktır. Aşağıda bir ekran görüntüsü gösterilmektedir -

Bir kez Create Yeni bir tarif oluşturmak için butonuna tıklayın, kaydınız tarifler tablosuna eklenir ve aşağıdaki sonucu gösterir -

Kayıtları düzenleme, gösterme ve imha etme seçeneğini görebilirsiniz. Öyleyse, bu seçeneklerle oynayın.

Ayrıca http://127.0.0.1:3000/recipe/list URL'sini kullanarak tarifler tablosunda bulunan tüm tarifleri listeleyebilirsiniz.

Modeli Geliştirmek

Rails size ücretsiz olarak birçok hata işleme olanağı sunar. Bunu anlamak için boş tarif modeline bazı doğrulama kuralları ekleyin -

App / models / recipe.rb dosyasını aşağıdaki gibi değiştirin ve ardından uygulamanızı test edin -

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

Bu girişler otomatik kontrol sağlayacaktır.

  • validates_length_of - alan boş değil ve çok uzun değil.

  • validates_uniqueness_of- yinelenen değerler yakalanır. Varsayılan Rails hata mesajı yerine, burada özel bir mesaj verdik.

İskele Oluşturmanın Alternatif Yolu

Yukarıda gösterildiği gibi bir uygulama oluşturun ve The Generated Scaffold Code Aşağıda gösterildiği gibi

rails g scaffold Recipe tittle:string instructions:text

Yukarıdaki kod, bir görüntünün altında gösterildiği gibi başlık ve komut sütunu ile sqlite3 ile kullanarak veri tabanına sahip otomatik dosyaları oluşturur.

aşağıdaki sözdizimini kullanarak veri tabanını taşımamız gerekiyor.

$ rake db:migrate RAILS_ENV=development

Son olarak, aşağıdaki komut satırını kullanarak uygulamayı çalıştırın -

rails server

Çıktı görüntülerinin yukarıda gösterildiği gibi sonucu üretecektir.

Görünümler

Tüm görünümler ve bunlara karşılık gelen tüm denetleyici yöntemleri, scaffold komutu ve app / views / recipe dizininde mevcuttur.

İskele Nasıl Farklıdır?

Önceki bölümleri geçtiyseniz, verileri listelemek, göstermek, silmek ve oluşturmak vb. İçin yöntemler yarattığımızı görmüş olmalısınız, ancak iskele bu işi otomatik olarak yapar.