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 คำสั่งและมีอยู่ในไดเร็กทอรีแอพ / มุมมอง / สูตรอาหาร
นั่งร้านแตกต่างกันอย่างไร?
หากคุณได้อ่านบทก่อนหน้านี้คุณจะต้องเห็นว่าเราได้สร้างวิธีการแสดงรายการแสดงลบและสร้างข้อมูล ฯลฯ แต่นั่งร้านทำงานนั้นโดยอัตโนมัติ