`
yanzilee9292
  • 浏览: 534651 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

Rails3入门锦集(7) 构建多模型表单 视图帮助器

阅读更多

入门锦集1-8都来自官方的翻译:http://edgeguides.rubyonrails.org/getting_started.html

 

 

1. 构建多模型表单

现在的博客一般都有便签功能, 方便读者通过关键字索引文章. 要实现该特性你的应用需要在一个表单中交互多个模型. 那么这时候Rails提供了另一个重要的功能: 嵌套表单

 

为了展示, 我们将为post的多标签提供支持. 首先, 我们需要为标签创建模型:

 

$ rails g model tag name:string post:references

 

然后:

 

$ rake db:migrate

 

接下来, 编辑post.rb建立另一半关联, 并告诉rails你需要通过posts来编辑tags:

 

class Post < ActiveRecord::Base
  validates :name,  :presence => true
  validates :title, :presence => true,
                    :length => { :minimum => 5 }
 
  has_many :comments, :dependent => :destroy
  has_many :tags #实际上对于标签来说应该是一个多对多的关联, 为了方便教程我在这里使用一对多关系
 
  accepts_nested_attributes_for :tags, :allow_destroy => :true,
    :reject_if => proc { |attrs| attrs.all? { |k, v| v.blank? } }
end

 

 :allow_destroy 告诉rails在视图上显示一个移除复选框, 而 :reject_if 将会阻止任何空属性的标签的保存.

现在我们修改 views/posts/_form.erb 模板来加入tag:

    <% @post.tags.build %>
    <%= form_for(@post) do |post_form| %>
      <% if @post.errors.any? %>
        <div id="error_explanation">
          <h2><%= pluralize(@post.errors.count, "error") %> prohibited this post from being saved:</h2>
    
          <ul>
          <% @post.errors.full_messages.each do |msg| %>
            <li><%= msg %></li>
          <% end %>
          </ul>
        </div>
      <% end %>
    
      <div class="field">
        <%= post_form.label :name %><br />
        <%= post_form.text_field :name %>
      </div>
      <div class="field">
        <%= post_form.label :title %><br />
        <%= post_form.text_field :title %>
      </div>
      <div class="field">
        <%= post_form.label :content %><br />
        <%= post_form.text_area :content %>
      </div>
      <h2>Tags</h2>
      <%= render :partial => "tags/form", :locals => {:form => post_form} %>
      <div class="actions">
        <%= post_form.submit %>
      </div>
    <% end %>
    

     

    现在我们把 form_for @post do |f| 改为 |psot_form| 使之更容易理解.

     

    本示例显示了 render方法的另一个参数 :locals 它可以传递局部变量, 在这里我们希望 form 变量映射为 post_form 对象.

     

    同时我们还在开始处初始化一个tag对象. (试试取消该行会发生什么)

     

    现在创建文件夹 views/tags/ 然后在里面添加一个 _form.erb 局部模板:

      <%= form.fields_for :tags do |tag_form| %>
        <div class="field">
          <%= tag_form.label :name, 'Tag:' %>
          <%= tag_form.text_field :name %>
        </div>
        <% unless tag_form.object.nil? || tag_form.object.new_record? %>
          <div class="field">
            <%= tag_form.label :_destroy, 'Remove:' %>
            <%= tag_form.check_box :_destroy %>
          </div>
        <% end %>
      <% end %>

       

      同样, 请留意下tags表单生成的html代码.

       

      最后, 我们编辑show.html.erb来显示这些tags:

        <p class="notice"><%= notice %></p>
         
        <p>
          <b>Name:</b>
          <%= @post.name %>
        </p>
         
        <p>
          <b>Title:</b>
          <%= @post.title %>
        </p>
         
        <p>
          <b>Content:</b>
          <%= @post.content %>
        </p>
         
        <p>
          <b>Tags:</b>
          <%= @post.tags.map { |t| t.name }.join(", ") %>
        </p>
         
        <h2>Comments</h2>
        <%= render @post.comments %>
         
        <h2>Add a comment:</h2>
        <%= render "comments/form" %>
         
         
        <%= link_to 'Edit Post', edit_post_path(@post) %> |
        <%= link_to 'Back to Posts', posts_path %> |

         

         现在你可以直接在创建或编辑post页面中添加或删除tags了.

         

        不过 @post.tags.map { |t| t.name }.join(", ") 感觉不是那么友好, 我们可以通过帮助器来改变.

         

         

        2. 视图帮助器

        视图帮助器位于 app/helpers, 可以提供一些可重用的视图代码片段. 在这里, 我们需要把所有tags的名称连起来并用逗号隔开, 由于它位于Posts视图, 那么我们可以在 PostsHelper 中实现:

          module PostsHelper
            def join_tags(post)
              post.tags.map { |t| t.name }.join(", ")
            end
          end

           

           然后把上面的 <%= @post.tags.map { |t| t.name }.join(", ") %> 改为:

          <%= join_tags @post %>

           

           

           

          转自: http://onia.iteye.com/blog/833152

          分享到:
          评论

          相关推荐

            Ruby on Rails入门例子

            总的来说,"Ruby on Rails入门例子"将带你了解Rails的基本架构和工作流程,通过实践操作,你会掌握如何构建一个完整的Web应用。在这个过程中,你还会接触到数据库设计、RESTful API、表单处理、错误处理和安全控制等...

            ruby on rails入门

            - **快速开发**:Rails 提供了一种称为“脚手架”(Scaffold) 的工具,能够自动生成基础的模型、视图和控制器代码,极大提高了开发效率。同时,Rails 内置了对数据库操作的支持,可以快速地进行数据交互。 - **文档...

            Beginning.Rails.3

            ### 关于《Beginning ...综上所述,《Beginning Rails 3》是一本非常适合Ruby on Rails初学者的入门书籍,不仅覆盖了Rails 3的基础知识,还包含了大量实用案例和技巧,能够帮助读者快速成长为有能力的Rails开发者。

            Ruby on Rails 入门经典教程

            Rails的MVC设计模式将应用程序分为模型(Model)、视图(View)和控制器(Controller)三个部分,分别负责数据处理、用户界面展示和业务逻辑控制。读者将学习如何创建和管理数据库模型,编写控制器方法,以及构建...

            rails2-sample

            从给定的文件信息来看,我们正在探讨的是一本关于Ruby on ...综上所述,《Simply Rails2》不仅为初学者提供了全面的Ruby on Rails入门指南,也为进阶开发者提供了深入的技术细节和实践案例,是一本值得推荐的学习资料。

            Rails入门教程二(翻译)

            ### Rails入门教程二知识点解析 #### 一、Rails框架简介及环境配置 - **Rails**:全称为**Ruby on Rails**,是一种使用Ruby语言开发的Web应用框架,它遵循MVC(Model-View-Controller)架构模式,具有高度的开发...

            RailsGuides中那个blog程序源码

            **Ruby on Rails(RoR)** 是一个基于Ruby语言的开源Web开发框架,它遵循MVC(模型-视图-控制器)架构模式,用于构建高效、简洁和可维护的Web应用。RailsGuides中的"blog"程序是一个典型的入门级示例,旨在帮助初学...

            Ruby on Rails Guides v2 - Ruby on Rails 4.2.5

            - **学习路径**:继续深入学习Rails的高级特性,如Active Record模式、表单构建器等。 - **社区资源**:加入Rails官方论坛、Stack Overflow等社区获取帮助和支持。 #### 十一、文档编写技巧 - **重要性**:良好的...

            Beginning Rails 4

            此外,还介绍了模型-视图-控制器(Model-View-Controller, MVC)架构模式,并具体说明了 Rails 如何实现这一模式中的每个组成部分。 - **约定优于配置**:Rails 强调通过合理的默认设置来减少开发人员需要编写的...

            Ruby on Rails 指南 v5.0.1 中文版

            #### Rails入门 - **前提条件**:为了能够顺利地开始Rails的学习之旅,读者需要具备一定的Ruby语言基础,并且对Web开发有一定的了解。 - **Rails是什么?**:Rails是一种用于开发服务器端应用程序的模型-视图-控制...

            simply rails

            《Simply Rails》是由Patrick Lenz编写的第二版书籍,旨在为初学者提供全面且深入的Ruby on Rails(简称Rails)入门指南。Rails是基于Ruby语言的一款开源Web开发框架,以其简洁、高效及DRY(Don't Repeat Yourself)...

            Agile Web Development with Rails, 4th Edition, Rails 3.1

            - 本书详细阐述了如何在Rails中构建表单,并介绍了强大的内置验证机制,帮助开发者轻松实现复杂的数据验证逻辑。 6. **测试驱动开发(TDD)** - 测试是确保软件质量的关键环节,TDD鼓励开发者先编写测试用例再...

            SitePoint[1].Simply.Rails.2.2nd.Edition.May.2008.pdf

            4. **Rails框架揭秘**:解析Rails的工作原理,包括路由机制、控制器、模型和视图的概念及其相互作用,以及如何利用Rails构建动态网站。 5. **模型、视图和控制器(MVC)**:深入探讨MVC设计模式在Rails中的实现,...

            Build.Your.Own.Ruby.on.Rails.Web.Applications.Feb.2007.pdf

            - **框架概述**:本书首先介绍了Ruby on Rails(RoR)框架的基本概念和历史背景,RoR是一个开源的Web应用框架,基于Ruby语言,采用了模型-视图-控制器(MVC)架构模式。 - **框架优势**:强调了RoR的简洁性、生产力...

            Simply Rails 2 2nd Edition (2008)

            - **主要内容**:重点讲解MVC模式下各组成部分的具体实现,包括如何定义模型、编写控制器逻辑、设计视图展示等。 - **学习目标**:掌握Rails应用程序的MVC架构,能够独立完成基本的CRUD操作。 ##### 第6章:辅助...

            CodeIgniter入门

            从创建一个带有联系人表单的简单Web页面开始,文档逐步引导读者了解如何安装和配置CodeIgniter,如何利用MVC架构来组织项目代码,以及如何通过控制器将模型和视图联系起来。 综上所述,CodeIgniter凭借其简洁的MVC...

            Codelgniter_入门

            完成这些步骤后,便可以创建控制器、模型和视图,构建第一个简单的Web页面,比如一个联系表单。 在创建控制器时,会定义一个或多个处理用户请求的方法,比如`contact()`。模型将包含处理表单提交的数据并可能与...

            RoR 培训课程PPT

            - **生成器和脚本**:介绍Rails提供的生成器工具,帮助开发者快速创建模型、控制器、视图等组件,同时学习如何编写自定义脚本来执行特定任务。 - **迁移**:解释数据库迁移的概念,展示如何使用Rails的迁移机制...

          Global site tag (gtag.js) - Google Analytics