Ruby on Rails,创建最简单的视图/控制器单元Hello World

在Ruby on Rails,创建一个最简单的站点中我们通过rails new simple_site命令创建了一个web应用骨架。笔墨纸砚都准备好了,该是时候写出第一个Hello World啦~!

Rails明确的按照MVC结构组织内容,回想一下MVC结构的简单知识。Browser(浏览器)向Controller(控制器)发出交互请求;Controller对请求做出分发处理调用Model(模型)进行业务或者数据运算;Controller将Model运算的结果推送给View(视图)使其在Browser中绘制显示。作为Hello World来说,建立一个从Browser到Controller再到View的例子既简单有很能说明问题。也就是说这个例子中不涉及与模型及数据库的任何操作,只是由Controller根据Browser发来的请求进行相应,并将相应交给View显示在Browser上。

Ruby on Rails,创建最简单的视图/控制器单元Hello World_第1张图片

进入应用目录simple_site,使用生成命令rails generate。这个命令负责在当前目录按照参数要求生成目录结构及代码。不带任何参数的命令会显示提示信息。

[plain]  view plain copy
  1. E:\greensoft\RailsInstaller\Sites\simple_site>rails generate  
  2. Usage: rails generate GENERATOR [args] [options]  
  3.   
  4. General options:  
  5.   -h, [--help]     # Print generator's options and usage  
  6.   -p, [--pretend]  # Run but do not make any changes  
  7.   -f, [--force]    # Overwrite files that already exist  
  8.   -s, [--skip]     # Skip files that already exist  
  9.   -q, [--quiet]    # Suppress status output  
  10.   
  11. Please choose a generator below.  
  12.   
  13. Rails:  
  14.   assets  
  15.   controller  
  16.   generator  
  17.   helper  
  18.   integration_test  
  19.   mailer  
  20.   migration  
  21.   model  
  22.   observer  
  23.   performance_test  
  24.   resource  
  25.   scaffold  
  26.   scaffold_controller  
  27.   session_migration  
  28.   task  
  29.   
  30. Coffee:  
  31.   coffee:assets  
  32.   
  33. Jquery:  
  34.   jquery:install  
  35.   
  36. Js:  
  37.   js:assets  
 我们需要创建Controller和View,使用rails generate controller命令。不带任何参数的命令会对创建controller的使用方式进行提示,应该静下心来读一读。其中最有用的部分是说,以CamelCase(大写字母开头分割单词)或者under_scored(下划线分割单词)的方式命名Controller,将View名称列表以参数的方式给出。后面还举了一个很典型的例子。

[plain]  view plain copy
  1. E:\greensoft\RailsInstaller\Sites\simple_site>rails generate controller  
  2. Usage:  
  3.   rails generate controller NAME [action action] [options]  
  4.   
  5. Options:  
  6.       [--skip-namespace]        # Skip namespace (affects only isolated applications)  
  7.       [--old-style-hash]        # Force using old style hash (:foo => 'bar') on Ruby >= 1.9  
  8.   -e, [--template-engine=NAME]  # Template engine to be invoked  
  9.                                 # Default: erb  
  10.   -t, [--test-framework=NAME]   # Test framework to be invoked  
  11.                                 # Default: test_unit  
  12.       [--helper]                # Indicates when to generate helper  
  13.                                 # Default: true  
  14.       [--assets]                # Indicates when to generate assets  
  15.                                 # Default: true  
  16.   
  17. Runtime options:  
  18.   -f, [--force]    # Overwrite files that already exist  
  19.   -p, [--pretend]  # Run but do not make any changes  
  20.   -q, [--quiet]    # Supress status output  
  21.   -s, [--skip]     # Skip files that already exist  
  22.   
  23. Description:  
  24.     Stubs out a new controller and its views. Pass the controller name, either  
  25.     CamelCased or under_scored, and a list of views as arguments.  
  26.   
  27.     To create a controller within a module, specify the controller name as a  
  28.     path like 'parent_module/controller_name'.  
  29.   
  30.     This generates a controller class in app/controllers and invokes helper,  
  31.     template engine and test framework generators.  
  32.   
  33. Example:  
  34.     `rails generate controller CreditCard open debit credit close`  
  35.   
  36.     Credit card controller with URLs like /credit_card/debit.  
  37.         Controller:      app/controllers/credit_card_controller.rb  
  38.         Functional Test: test/functional/credit_card_controller_test.rb  
  39.         Views:           app/views/credit_card/debit.html.erb [...]  
  40.         Helper:          app/helpers/credit_card_helper.rb  
我们要创建一个名为demo的Controller,指向名为index的View。在这里可以使用g来代替generate,就像s代替service一样。回显信息告诉我们,rails为我们在app/controller目录中创建了一个名为demo_controller的Controller。app/views/目录中创建了一个名为demo的目录,目录中的index.html.erb对应View。
[plain]  view plain copy
  1. E:\greensoft\RailsInstaller\Sites\simple_site>rails g controller demo index  
  2.       create  app/controllers/demo_controller.rb  
  3.        route  get "demo/index"  
  4.       invoke  erb  
  5.       create    app/views/demo  
  6.       create    app/views/demo/index.html.erb  
  7.       invoke  test_unit  
  8.       create    test/functional/demo_controller_test.rb  
  9.       invoke  helper  
  10.       create    app/helpers/demo_helper.rb  
  11.       invoke    test_unit  
  12.       create      test/unit/helpers/demo_helper_test.rb  
  13.       invoke  assets  
  14.       invoke    coffee  
  15.       create      app/assets/javascripts/demo.js.coffee  
  16.       invoke    scss  
  17.       create      app/assets/stylesheets/demo.css.scss  
controller目录中名为demo的Controller里有一个名为index的方法,在在这里应该叫做action。这个叫index的action,对应views目录中名为index.html.erb的View。
[ruby]  view plain copy
  1. class DemoController < ApplicationController  
  2.   def index  
  3.   end  
  4. end  

修改一下页面内容

[html]  view plain copy
  1. <h1>Demo#index</h1>  
  2. <p>Hello World!</p>  
[html]  view plain copy
  1. <p>Find me in app/views/demo/index.html.erb</p>  

代码编写完毕,启动web服务器。在浏览器地址栏中输入:localhost:3000/demo/index。里程碑!

Ruby on Rails,创建最简单的视图/控制器单元Hello World_第2张图片

你可能感兴趣的:(Ruby on Rails,创建最简单的视图/控制器单元Hello World)