Rails的學習我主要基于《Ruby on rails 教程》《Agile Web Development with Rails 4 》,官網(wǎng)的API文檔和 來自Ruby-China的指南(http://guides.ruby-china.org/index.html)來學習,整體上按照《Agile Web Development with Rails 4 》的目錄順序記述。
網(wǎng)站建設、成都網(wǎng)站制作,成都做網(wǎng)站公司-創(chuàng)新互聯(lián)建站已向成百上千家企業(yè)提供了,網(wǎng)站設計,網(wǎng)站制作,網(wǎng)絡營銷等服務!設計與技術結合,多年網(wǎng)站推廣經(jīng)驗,合理的價格為您打造企業(yè)品質網(wǎng)站。
美好的學習從創(chuàng)建項目開始。。
Rails自帶了一整套命令行工具
首先創(chuàng)建了work目錄并進入
然后 使用rails new demo
創(chuàng)建了一個名為demo的項目
如下圖所示
當如下圖顯示時說明創(chuàng)建完成
項目結構如下圖顯示
下圖是各個文件夾的用途:圖源:http://guides.ruby-china.org/index.html
執(zhí)行rake baout 能查看安裝信息(只截取了部分內容)
rake about 還會檢測是否有安裝錯誤
一切ok后,執(zhí)行rails s (rails server的簡寫)
由于這個虛擬環(huán)境已經(jīng)安裝了nodejs,所以沒有出現(xiàn)JavaScript runtime 錯誤,能夠正常執(zhí)行
結果如下:
vagrant已經(jīng)設置了private_network 并指定ip為192.168.33.10,所以直接訪問 http://192.168.33.10:3000/ 結果如下:
又見hello,Rails。。。我為什么要加個又呢冏
rails g controller Say hello goodbye (rails generate)用于生成控制器
打開demo/app/controllers/say_controller.rb 生成結果如下
Rails 與請求URL
啟動服務器后 訪問http://192.168.33.10:3000/say/hello
出現(xiàn)下圖:
如圖所示,Rails 默認會尋找與控制器同名的模板文件,打開模板文件顯示如下
修改后:
刷新游覽器后
一個請求的執(zhí)行流程如下:(摘自《Ruby on rails 教程》)
Rails接受一個請求后,交由控制器處理,由控制器決定下一步如何處理,是立即渲染視圖并返回給游覽器或是先與model交互再渲染視圖。寫到這兒,有點好奇Django的MTV模式,有空也好好琢磨下。
添加點動態(tài)內容
打開模板文件修改如下:
刷新頁面,顯示如下:
添加時間的改良版寫法
控制器:
模板:
以上的代碼展現(xiàn)了Rails 約定大于配置的原則。。
添加鏈接
首先修改demo/app/views/say/goodbye.html.erb 結果如下
頁面顯示如下:
添加鏈接啦!
修改hello和goodbye模板如下:
hello
goodbye:
結果:
點擊后:
書上第二章到此結束! 撒花??!
補充:
本地生成api文檔的方法
rails new projectname
cd projectname
rake doc:rails # 生成API文檔