रूबी ऑन रेल्स - मचान

जब आप रेल एप्लिकेशन विकसित कर रहे हों, विशेष रूप से वे जो मुख्य रूप से आपको डेटाबेस में डेटा के लिए एक सरल इंटरफ़ेस प्रदान कर रहे हैं, तो यह अक्सर पाड़ विधि का उपयोग करने के लिए उपयोगी हो सकता है।

मचान सस्ते डेमो थ्रिल से अधिक प्रदान करता है। यहाँ कुछ लाभ दिए गए हैं -

  • आप प्रतिक्रिया के लिए अपने उपयोगकर्ताओं के सामने जल्दी से कोड प्राप्त कर सकते हैं।

  • आप तेज सफलता से प्रेरित हैं।

  • आप जनरेट किए गए कोड को देखकर जान सकते हैं कि रेल कैसे काम करती है।

  • आप अपने विकास को शुरू करने के लिए एक नींव के रूप में मचान का उपयोग कर सकते हैं।

मचान उदाहरण

मचान को समझने के लिए, आइए एक डेटाबेस बनाएंcookbook और एक मेज बुलाया recipes

एक खाली रेल वेब अनुप्रयोग बनाना

एक कमांड विंडो खोलें और उस जगह पर नेविगेट करें जहां आप इसे बनाना चाहते हैं 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)

डेटाबेस को खोजने के लिए रेल को निर्देश देने के लिए, कॉन्फ़िगरेशन फ़ाइल cookbook \ config \ database.yml को संपादित करें और डेटाबेस का नाम रसोई की किताब में बदलें। पासवर्ड खाली छोड़ दें। जब आप पूरा कर लें, तो यह इस प्रकार दिखना चाहिए -

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

रेल आपको विभिन्न डेटाबेस का उपयोग करके विकास मोड, परीक्षण मोड, या उत्पादन मोड में चलाने की सुविधा देती है। यह एप्लिकेशन प्रत्येक के लिए एक ही डेटाबेस का उपयोग करता है।

उत्पन्न पाड़ कोड

पाड़ कार्रवाई के साथ, रेल गतिशील रूप से इसकी आवश्यकता वाले सभी कोड उत्पन्न करता है। स्क्रिप्ट के रूप में मचान को चलाकर , हम डिस्क पर लिखे गए सभी कोड प्राप्त कर सकते हैं, जहां हम इसकी जांच कर सकते हैं और फिर इसे अपनी आवश्यकताओं के अनुरूप बनाना शुरू कर सकते हैं।

तो अब, एक बार फिर से शुरू करते हैं कि स्कैफोल्ड हेल्पर स्क्रिप्ट का उपयोग करके मैन्युअल रूप से स्कैफोल्ड कोड उत्पन्न करें -

cookbook> rails generate scaffold recipe

यह नीचे दिखाए गए अनुसार ऑटो-फाइलें उत्पन्न करता है -

नियंत्रक

नियंत्रक के पीछे कोड को देखते हैं। इस कोड से उत्पन्न होता हैscaffoldजनरेटर। अगर आप ऐप / कंट्रोलर / रेसिपी_कंट्रोलर.आरबी खोलते हैं, तो आपको कुछ इस प्रकार मिलेगा -

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

जब रेल एप्लिकेशन का उपयोगकर्ता एक क्रिया का चयन करता है, उदाहरण के लिए "शो" - नियंत्रक उपयुक्त अनुभाग में किसी भी कोड को निष्पादित करेगा - "शो दिखाएं" - और फिर डिफ़ॉल्ट रूप से उसी नाम का एक टेम्पलेट प्रस्तुत करेगा - "show.html।" ERB "। यह डिफ़ॉल्ट व्यवहार अधिलेखित किया जा सकता है।

नियंत्रक ActiveRecord विधियों जैसे कि find, find_all, new, save, update_attributes का उपयोग करता है, और डेटाबेस तालिकाओं से डेटा को स्थानांतरित करने के लिए नष्ट कर देता है। ध्यान दें कि आपको किसी भी एसक्यूएल स्टेटमेंट को लिखने की ज़रूरत नहीं है, रेल अपने आप इसका ख्याल रखेगा।

कोड की यह एकल पंक्ति जीवन के लिए डेटाबेस तालिका लाएगी। यह आपके डेटा, और के तरीकों के लिए एक सरल इंटरफ़ेस प्रदान करेगा -

  • नई प्रविष्टियां बनाना
  • वर्तमान प्रविष्टियों का संपादन
  • वर्तमान प्रविष्टियां देखना
  • वर्तमान प्रविष्टियों को नष्ट करना

प्रविष्टि बनाते या संपादित करते समय, मचान आपके लिए फ़ॉर्म जनरेशन और हैंडलिंग जैसे सभी कठिन कार्य करेगा, और निम्न प्रकार के इनपुट्स का समर्थन करते हुए, चतुर फ़ॉर्म जेनरेशन भी प्रदान करेगा -

  • सरल पाठ तार
  • पाठ क्षेत्र (या पाठ के बड़े ब्लॉक)
  • तिथि चयनकर्ता
  • तिथि-समय चयनकर्ता

तालिकाओं को बनाने और बनाए रखने के लिए आप रेल माइग्रेशन का उपयोग कर सकते हैं।

rake db:migrate RAILS_ENV=development

अब, कुकबुक डायरेक्टरी में जाएं और निम्न कमांड का उपयोग करके वेब सर्वर चलाएं -

cookbook> rails server

अब, एक ब्राउज़र खोलें और नेविगेट करें http://127.0.0.1:3000/recipe/new.यह आपको व्यंजनों तालिका में नई प्रविष्टियां बनाने के लिए एक स्क्रीन प्रदान करेगा। एक स्क्रीनशॉट नीचे दिखाया गया है -

एक बार दबाएं Create एक नया नुस्खा बनाने के लिए बटन, आपका रिकॉर्ड व्यंजनों की तालिका में जोड़ा गया है और यह निम्न परिणाम दिखाता है -

आप रिकॉर्ड को संपादित करने, दिखाने और नष्ट करने का विकल्प देख सकते हैं। इसलिए, इन विकल्पों के साथ खेलें।

आप URL http://127.0.0.1:3000/recipe/list का उपयोग करके रेसिपी टेबल में उपलब्ध सभी व्यंजनों को सूचीबद्ध कर सकते हैं।

मॉडल को बढ़ाना

रेल आपको फ्री में बहुत सी एरर हैंडलिंग प्रदान करती है। इसे समझने के लिए, खाली नुस्खा मॉडल में कुछ सत्यापन नियम जोड़ें -

एप्लिकेशन / मॉडल / रेसिपी को संशोधित करें। इस प्रकार से और फिर अपने आवेदन का परीक्षण करें -

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- डुप्लिकेट मान फंस गए हैं। डिफ़ॉल्ट रेल त्रुटि संदेश के बजाय, हमने यहां एक कस्टम संदेश दिया है।

मचान बनाने का वैकल्पिक तरीका

जैसा कि ऊपर दिखाया गया है एक एप्लिकेशन बनाएं और The Generated Scaffold Code जैसा की नीचे दिखाया गया

rails g scaffold Recipe tittle:string instructions:text

ऊपर दिए गए कोड छवि के नीचे दिखाए गए अनुसार tl औरite कॉलम के साथ sqlite3 का उपयोग करके डेटा बेस के साथ ऑटो फ़ाइलों को उत्पन्न करता है।

हमें सिंटैक्स का उपयोग करके डेटा बेस को माइग्रेट करने की आवश्यकता है।

$ rake db:migrate RAILS_ENV=development

अंत में निम्नलिखित कमांड लाइन का उपयोग करके एप्लिकेशन चलाएं -

rails server

यह आउटपुट छवियों के ऊपर दिखाए गए परिणाम उत्पन्न करेगा।

विचार

सभी व्यूअर और संबंधित सभी कंट्रोलर मेथड द्वारा बनाए गए हैं scaffold कमांड और वे ऐप / विचार / व्यंजनों निर्देशिका में उपलब्ध हैं।

कैसे मचान अलग है?

यदि आप पिछले अध्यायों से गुजरे हैं, तो आपने देखा होगा कि हमने डेटा को सूचीबद्ध करने, दिखाने, हटाने और बनाने आदि के लिए तरीके बनाए थे, लेकिन मचान उस काम को स्वचालित रूप से करता है।