(源自:http://www.netbeans.org/kb/60/ruby/rapid-ruby-weblog_zh_CN.html)
作者:Brian Leonard
2007 年 9 月 [修订编号:V 6.0-4]
在本教程中,我将利用 NetBeans IDE 对 Ruby 的支持创建一个简单的 Web 应用程序。本文将演示如何创建一个 Ruby 博客程序。您将遵循这些基本流程创建模型、添加控制器并生成视窗。
内容
- | 教程需求 |
- | 创建示例数据库 |
- | 创建 Ruby on Rails 项目 |
- | 配置数据库环境 |
- | 创建模型 |
- | 迁移数据库 |
- | 创建一个控制器 |
- | 运行应用程序 |
- | 更多功能:再添加另一个字段 |
- | 更多功能:使列表看起来更像是一个博客 |
本教程需要以下技术和资源:
注意:本教程使用 MySQL 数据库服务器。有关在 Ruby 应用程序中有使用MySQL 数据库服务器的信息,请参阅 安装和配置 Ruby 支持。本文档中同样包括如何使用 Java DB 数据库服务器的技巧。
创建 Ruby on Rails 项目之前,首先需要先创建一个 rubyweblog_development 数据库。步骤如下:
mysqladmin -u root -p create rubyweblog_development注意: 如果根用户未设置口令,则省略 -p 参数。
注意:首次在 IDE 中创建 Ruby 项目时,IDE 会检查系统中是否还安装了其他 Ruby 软件(除了 IDE 随带的 JRuby 软件之外)。如果有,IDE 会弹出一个对话框,询问您选择使用哪一个软件。如果要使用 IDE 随带的 JRuby 解释器,就选择 JRuby,反之,选择安装的 Ruby。有关更多信息,请参阅安装和配置 Ruby 教程中的 Configuring the IDE to Use Your Own Ruby Installation 一节。
RubyWebLog
。接受所有其他默认设置。IDE 将创建一个项目目录,名称与您的项目名称相同。您将看到:
database.yml
文件,在 development 配置中添加口令。database.yml
文件。在本节中,您将利用 Rails Generator 创建应用程序的模型。Ruby 博客应用程序需要使用 Post 模型存储博客文章的实例。
Rails Generator 将创建一个名为 Post 的模型。Output 窗口将列出该操作创建的文件:
001_create_posts.rb
。首先添加信息配置数据库。
在 Output 窗口中,单击 001_create_posts.rb
文件的链接。
打开该文件,可以看到一个 self.up
方法(用于创建 posts 表)和一个 self.down
方法(用于释放 posts 表)。
将标题栏(以下代码的黑体部分)添加到 self.up
方法的 create_table
中,如下图所示:
代码示例 1: 001_create_posts.rb 的代码 |
class CreatePosts < ActiveRecord::Migration def self.up create_table :posts do |t| t.column "title", :string end end def self.down drop_table :posts end end |
在 Projects 窗口中,右键单击 RubyWebLog 节点,然后选择 Migrate Database > To Current Version。
该操作将更新数据库,使数据库中含有 posts 表。Output 窗口将显示迁移何时完成。
在 Projects 窗口中,右键单击 Controllers 节点,选择 Generate。
在 Rails Generator 对话框的 Name 栏中输入 Blog
,置空 Views 栏,单击 OK 按钮。这样将创建一个 blog_controller.rb
文件,并在编辑域中打开该文件。这时,Projects 窗口的 Controllers 节点中就添加了一个 blog_controller.rb 节点。
编辑 blog_controller.rb
,在其中添加以下 scaffolding 代码。此代码将为 Post 模型提供一个简单的 CRUD 应用程序。
代码示例 2: blog_controller.rb 的代码 |
class BlogController < ApplicationController scaffold :post end |
在 Configuration 节点中,打开 routes.rb。
找到下面这行代码:
# map.connect '', :controller => "welcome"
welcome
修改为 blog
。展开 Public 节点,右键单击 index.html,然后选择 Delete。
index.html
将默认显示 Welcome 页面,而这并不是您想要的。通过删除 index.html
, Rails 将在 routes.rb
中寻找需要显示的页面。在前面的步骤中,我们已经将 welcome 页面已经修改为 blog。
单击工具栏中的 Run Main Project 按钮。
该操作将启动 WEBrick 服务器,它是 Ruby on Rails 框架的一部分。同时将启动 web 浏览器。下图是该应用程序的初始页面。
图 1: RubyWebLog 主页
单击 New 按钮。
图 2: 创建新日志
输入一个标题,然后单击 Create 按钮。
下图就是创建博客日志的一个例子。
图 3: 成功创建博客日志
右键单击 Database Migrations 节点,选择 Generate。 在 Rails Generator 对话框的 Arguments 栏中输入 AddBody
,然后单击 OK 按钮。
IDE 将创建一个迁移脚本版本文件 002_add_body.rb
,并在编辑域中打开该文件。
对 002_add_body.rb
作如下修改:
代码示例 3: 002_add_body.rb 的代码 |
class AddBody < ActiveRecord::Migration def self.up add_column 'posts', 'body', :text end def self.down remove_column 'posts', :body end end |
返回浏览器,单击 New Post 链接,看 Ruby 如何识别新的正文字段。
图 4:含有正文字段的新日志
再创建一些博客条目。例如:
图 5: 更多博客日志
在 Model Name 栏中输入 Post
,在 Controller Name 栏中输入 Blog
。将 Actions 栏置空。选择 Overwrite,强制 BlogController 重新生成,然后单击 OK 按钮。IDE 会为 Post 模型创建一个视窗,并在 Output 窗口中列出内容。
展开 Views > blog,并打开 list.rhtml,
该文件用以显示博客条目的列表。 删除 <h1> 和 <table> 标记,并将其替换为下列代码:
代码示例 4:list.rhtml 代码 |
<h1>The Ruby Blog</h1> <% @posts.each do |post| %> <h2><%= post.title %></h2> <p><%= post.body %></p> <small> <%= link_to 'Permalink', :action => 'show', :id => post %></small> <hr> <% end %> |
此代码将为每个 post
操作实例都生成一个标题、正文和 Permalink,如图 6所示。
选择 File > Save All ,然后刷新浏览器,查看 Post 模型的新界面。
图 6: 新的、改进的模型界面
想要首先显示最新的条目,就需要通过在 @posts in list.rhtml
的末尾添加 .reverse 来反转排序次序:
<% @posts.reverse.each do |post| %>
保存文件并刷新浏览器,博客程序将显示如下内容:
图 7: 反序显示博客日志
要继续学习 Ruby 博客程序教程,以及了解有关 NetBeans IDE 中的 Ruby 支持的更多内容,请访问 Building a Relationship Between Rails Models。
要获得 NetBeans Ruby 的技术支持和最新开发的功能,请加入 users @ ruby.netbeans.org 和dev @ ruby.netbeans.org 邮件表。
>> 更多 NetBeans Ruby 文档