Ruby on Rails - นั่งร้าน

ในขณะที่คุณกำลังพัฒนาแอปพลิเคชัน Rails โดยเฉพาะอย่างยิ่งแอปพลิเคชันที่ให้อินเทอร์เฟซที่เรียบง่ายกับข้อมูลในฐานข้อมูลมักเป็นประโยชน์ในการใช้วิธีการนั่งร้าน

นั่งร้านให้ความตื่นเต้นมากกว่าการสาธิตราคาถูก นี่คือประโยชน์บางประการ -

  • คุณสามารถรับโค้ดต่อหน้าผู้ใช้ได้อย่างรวดเร็วเพื่อรับความคิดเห็น

  • คุณมีแรงจูงใจจากความสำเร็จที่เร็วขึ้น

  • คุณสามารถเรียนรู้ว่า Rails ทำงานอย่างไรโดยดูที่โค้ดที่สร้างขึ้น

  • คุณสามารถใช้นั่งร้านเป็นพื้นฐานเพื่อเริ่มต้นการพัฒนาของคุณ

ตัวอย่างนั่งร้าน

เพื่อทำความเข้าใจเกี่ยวกับโครงนั่งร้านเรามาสร้างฐานข้อมูลที่เรียกว่าcookbook และโต๊ะที่เรียกว่า recipes.

การสร้างแอปพลิเคชั่นเว็บ Rails ว่าง

เปิดหน้าต่างคำสั่งและไปที่ตำแหน่งที่คุณต้องการสร้าง 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 และเปลี่ยนชื่อฐานข้อมูลเป็นตำราอาหาร ปล่อยรหัสผ่านว่างไว้ เมื่อคุณทำเสร็จแล้วควรมีลักษณะดังนี้ -

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" - คอนโทรลเลอร์จะรันโค้ดใด ๆ ในส่วนที่เหมาะสม - "def show" - จากนั้นโดยค่าเริ่มต้นจะแสดงเทมเพลตที่มีชื่อเดียวกัน - "show.html erb ". พฤติกรรมเริ่มต้นนี้สามารถเขียนทับได้

ตัวควบคุมใช้เมธอด ActiveRecord เช่นfind, find_all, new, save, update_attributes และทำลายเพื่อย้ายข้อมูลเข้าและออกจากตารางฐานข้อมูล โปรดทราบว่าคุณไม่จำเป็นต้องเขียนคำสั่ง SQL ใด ๆ ทางรถไฟจะดูแลโดยอัตโนมัติ

โค้ดบรรทัดเดียวนี้จะทำให้ตารางฐานข้อมูลมีชีวิตชีวา จะมีอินเทอร์เฟซที่เรียบง่ายสำหรับข้อมูลของคุณและวิธีการ -

  • การสร้างรายการใหม่
  • การแก้ไขรายการปัจจุบัน
  • การดูรายการปัจจุบัน
  • กำลังทำลายรายการปัจจุบัน

เมื่อสร้างหรือแก้ไขรายการนั่งร้านจะทำงานหนักทั้งหมดเช่นการสร้างแบบฟอร์มและการจัดการให้กับคุณและยังให้การสร้างแบบฟอร์มที่ชาญฉลาดโดยรองรับอินพุตประเภทต่อไปนี้ -

  • สตริงข้อความธรรมดา
  • พื้นที่ข้อความ (หรือข้อความขนาดใหญ่)
  • ตัวเลือกวันที่
  • ตัวเลือกวันที่ - เวลา

คุณสามารถใช้ Rails Migrations เพื่อสร้างและดูแลตาราง

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

การปรับปรุงโมเดล

Rails ช่วยให้คุณจัดการข้อผิดพลาดมากมายได้ฟรี เพื่อให้เข้าใจสิ่งนี้เพิ่มกฎการตรวจสอบความถูกต้องลงในแบบจำลองสูตรอาหารที่ว่างเปล่า -

แก้ไขแอป / รุ่น / สูตรอาหารดังต่อไปนี้แล้วทดสอบแอปพลิเคชันของคุณ -

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 พร้อมคอลัมน์ tittle และคำสั่งดังที่แสดงด้านล่างภาพ

เราจำเป็นต้องย้ายฐานข้อมูลโดยใช้ไวยากรณ์ด้านล่าง

$ rake db:migrate RAILS_ENV=development

สุดท้ายเรียกใช้แอปพลิเคชันโดยใช้บรรทัดคำสั่งต่อไปนี้ -

rails server

มันจะสร้างผลลัพธ์ดังที่แสดงไว้ด้านบนภาพที่ส่งออก

มุมมอง

มุมมองทั้งหมดและวิธีการควบคุมทั้งหมดที่สอดคล้องกันถูกสร้างขึ้นโดย scaffold คำสั่งและมีอยู่ในไดเร็กทอรีแอพ / มุมมอง / สูตรอาหาร

นั่งร้านแตกต่างกันอย่างไร?

หากคุณได้อ่านบทก่อนหน้านี้คุณจะต้องเห็นว่าเราได้สร้างวิธีการแสดงรายการแสดงลบและสร้างข้อมูล ฯลฯ แต่นั่งร้านทำงานนั้นโดยอัตโนมัติ