萬事起頭難
Model
資料表存放的地方。任何關於欄位的限制(如:不可重複等)都規定在此。延續上一週[我在做什麼],我的Model應只有一個來存放App的資料,再用state-machine來控制每筆App的狀態,以下為我的sample code:
1 2 3 4 5 6 7 8 9 10 |
|
如此一來你可以執行該transition來更改你的狀態
1
|
|
Controller
對資料表執行某些動作的地方。基本的動作像是新增、讀取、更改、刪除(CRUD)都會被定義於controller中。有種設計風格叫做RESTful,它幫助我們用一種比較標準化的方式來命名跟組織controllers和actions,應盡量使用以降低controller的負擔。如果有重複使用的action應使用善加利用繼承概念以便未來網站維護之用。
1
|
|
在admin資料夾中新增一個base_controller.rb
1 2 3 |
|
然後再將admin/apps controller繼承base controller
1
|
|
透過物件導向的繼承概念,可以將避免重複的程式撰寫,方便未來網站管理。
View
如果使用RESTful的設計風格,再設計表單時你可以直接設定method即可透過http完成對model的操作。
1
|
|
Devise
一個註冊、登出登錄、更改密碼等多功能使用者管理套件,它可以讓你安全的存取使用者資訊,完善的api讓功能們隨call隨到。
Workers
幫助你定時完成某項任務。本網站需要每日定時更新資料庫中的資料才可以確保排名是即時的,因此可使用crobtab實現你的願望。若待處理事件需要queue來控管的話,可考慮使用resque和sidekiq
說的落落長卻少了成品,我會督促我自己在星期三前都摸摸看
重點只是想要說:有規劃的專案就像是有目標的船隻,船長才知道駛往何方
我們在開的船越來越大艘,有時候自己都覺得自己無力駕駛,很難想像有一天如果是開航空母艦,一次要跟上百個人合作的時候要怎麼辦?
從最簡化的狀況,就是需要充足的規劃,無論是一個人、兩個人或是十個人、數十個人的專案,應該都是如此。