约定优于配置RESTful是Ruby on Rails十分推崇的哲学。在一个默认的RESTful的Rails项目中,使用资源HTTP动词来帮助组织项目。

假如有一个使用scaffold创建的Rails项目,它的创建代码像下面这样:

rails new hello_rails
cd hello_rails/
rails generate scaffold person name:string

执行之后得到的文件结构如下(原文来自Ruby on Rails 指南):

  • app/ 存放程序的控制器、模型、视图、帮助方法、邮件和静态资源文件。本文主要关注的是这个文件夹。
  • bin/ 存放运行程序的 rails 脚本,以及其他用来部署或运行程序的脚本。
  • config/ 设置程序的路由,数据库等。详情参阅“设置 Rails 程序”一文。
  • config.ru 基于 Rack 服务器的程序设置,用来启动程序。
  • db/ 存放当前数据库的模式,以及数据库迁移文件。
  • Gemfile, Gemfile.lock 这两个文件用来指定程序所需的 gem 依赖件,用于 Bundler gem。关于 Bundler 的详细介绍,请访问 Bundler 官网。
  • lib/ 程序的扩展模块。
  • log/ 程序的日志文件。
  • public/ 唯一对外开放的文件夹,存放静态文件和编译后的资源文件。
  • Rakefile 保存并加载可在命令行中执行的任务。任务在 Rails 的各组件中定义。如果想添加自己的任务,不要修改这个文件,把任务保存在 lib/tasks 文件夹中。

    README.rdoc 程序的简单说明。你应该修改这个文件,告诉其他人这个程序的作用,如何安装等。
  • test/ 单元测试,固件等测试用文件。详情参阅“测试 Rails 程序”一文。
  • tmp/ 临时文件,例如缓存,PID,会话文件。
  • vendor/ 存放第三方代码。经常用来放第三方 gem。

项目中最常用的是app/这个目录,在它下面又有MVC模型的controllers/views/models/等几个子目录。

controllers/下面有people_controller.rb文件,其中的类叫做PeopleController。Rails约定,控制器中的命名默认为复数,如果你没有在路由中指定其他的控制器的话。我们创建的模型叫person,所以它的复数就是people。

在控制器中有indexshowneweditcreateupdatedestroy等方法,这些方法叫做控制器的动作。

models/下面有person.rb。Rails约定模型名默认是单数。打开这个文件后,里面却什么都没有。

class Person < ActiveRecord::Base
end

这是因为在Rails中,模型的内容是随着数据库中对应的表变化的,这一点和其他的ORM略有不同。如果需要修改模型的内容,只需修改数据库即可。而修改数据库并不需要手工去做,Rails中有迁移(migration)这个机制可以帮助我们实现。好处一是我们的修改是数据库无关的;二是可以方便做版本控制。

打开db/migrate/*_create_people.rb。这段代码创建了一张people表:

class CreatePeople < ActiveRecord::Migration
def change
create_table :people do |t|
t.string :name
t.timestamps
end
end
end

我们执行bin/rails db:migrate命名来执行迁移,这时Rails在后台建立了people表,使用的是config/database.yaml中设置的数据库,默认就是SQLite。

最后看一下views/目录。在它下面除了和布局相关的layouts/,就是people/目录。其中有以.html.erb为后缀的indexnewshowedit等文件。这些文件都和控制器的动作相关联。把它们关联在一起的就是Rails的路由设置config/routes.rb

这里面只有一条规则,

resources :people

创建了people这个资源。Rails使用资源来实现REST。它实际上等价于下面的几条规则:

或者借用Ruby on Rails 实战圣经的这个表格更好认识(原图中资源为events):

[Rails学习之路]Rails文件结构与路由的更多相关文章

  1. [Rails学习之路]Rails路由配置

    如果是使用Rails的默认约定,那么几乎是零配置. 但有些时候,我们可能不得不(或者更喜欢)进行一些特殊的配置. 其实Rails在路由功能中也有很丰富的配置选项. routes.rb文件中靠前的规则优 ...

  2. 开始了大概三四天的Rails学习之路

    最近因为一位极光推送朋友,我开始了大概三四天的Rails学习之路,最终达到的水平是可以比较轻松地做出大部分功能,然后自我感觉可以自如地按照Rails的设计思想去思考.由于编程的日益流行,我结识了越来越 ...

  3. [Rails学习之路]初识Ruby(一)

    Ruby是一门动态的.强类型的.纯面向对象的编程语言.它和Python非常相似,但比Python面向对象更加彻底.使用更加灵活.语法更加复杂.也更为有趣. 抛开做事情到底应该有多少种方法这个问题,我相 ...

  4. [Rails学习之路]初识Ruby(二)

    继续上次Ruby的学习.接下来就到了Ruby的方法. Ruby的方法与Python仍然很像.使用def定义,可以使用undef取消定义. 在Ruby中,经常可以看见方法后面跟有"?" ...

  5. WPF学习之路(四)路由

    路由事件概述 功能定义:路由事件是一种可以针对元素树中的多个侦听器(而不是仅针对引发该事件的对象)调用处理程序的事件. 实现定义:路由事件是一个 CLR 事件,可以由RouteEvent 类的实例提供 ...

  6. Rails学习:create操作 局部模板

    学习Ruby on Rails实战真经 里面说rails4使用了strong parameters, 所以代码这么写:注意不是Event.new(params[:event])了,而是参数是函数返回值 ...

  7. 【Ruby on Rails学习二】在线学习资料的整理

    由于工作任务重,时间紧,没有太多学习的时间,大致找了些在线学习资料,这里做个整理,希望对同样准备学习的朋友有帮助 在线文档类: Ruby on Rails 实战圣经  使用 Rails 4.2 及 R ...

  8. rails学习笔记: rake db 相关命令

    rails学习笔记: rake db 命令行 rake db:*****script/generate model task name:string priority:integer script/g ...

  9. springboot 学习之路 1(简单入门)

    目录:[持续更新.....] spring 部分常用注解 spring boot 学习之路1(简单入门) spring boot 学习之路2(注解介绍) spring boot 学习之路3( 集成my ...

随机推荐

  1. mysql的性能优化总结

    经验是从别人那里拿来的,不想直接复制黏贴,想亲自总结下,巴拉巴拉.........进入正题吧 一.为查询加入缓存 1.检查数据库是否开启缓存:show variables like '%query_c ...

  2. docker17.09.1-ce 执行systemctl resart docker重启失败的问题

    记录在实际操作中碰到的docker问题 环境信息: 安装完kolla ocata版本,并且编译成功各openstack 组件的容器镜像 [root@localhost ~]# docker --ver ...

  3. vue -- 打包资源正确引用及背景图引入

    一般情况下,通过webpack+vuecli默认打包的css.js等资源,路径都是绝对的. 但当部署到带有文件夹的项目中,这种绝对路径就会出现问题,因为把配置的static文件夹当成了根路径,那么要解 ...

  4. CF 983B XOR-pyramid(区间dp,异或)

    CF 983B XOR-pyramid(区间dp,异或) 若有一个长度为m的数组b,定义函数f为: \(f(b) = \begin{cases} b[1] & \quad \text{if } ...

  5. bzoj 3944: Sum(杜教筛)

    3944: Sum Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 4930  Solved: 1313[Submit][Status][Discuss ...

  6. linux_下IP、网关、DNS地址配置

    设置Linux网络的方法有两种: 第一种:修改配置文档(需要重启网络配置,永远生效)一.修改IP地址[aeolus@db1 network-scripts]$ vi ifcfg-eth0DEVICE= ...

  7. RabbitMQ简介和使用

    一.RabbitMQ简介 1.什么是RabbitMQ AMQP,即Advanced Message Queuing Protocol,高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设 ...

  8. Hadoop 2.0完全分布式集群搭建方法(CentOS7+Hadoop 2.7.7)

    本文详细介绍搭建4个节点的完全分布式Hadoop集群的方法,Linux系统版本是CentOS 7,Hadoop版本是2.7.7,JDK版本是1.8. 一.准备环境 1. 在VMware worksta ...

  9. Java基础笔记(十一)—— 字符串与数组

    字符串的声明与初始化主要两种:String s1=new String("abc");      或      String s2="abc"; String ...

  10. CCF201809(Java)

    第一题: 问题描述 在一条街上有n个卖菜的商店,按1至n的顺序排成一排,这些商店都卖一种蔬菜. 第一天,每个商店都自己定了一个价格.店主们希望自己的菜价和其他商店的一致,第二天,每一家商店都会根据他自 ...