Rails命名约定。
1. 混合大小写,下划线,复数
变量,全部字母都小写,单词的中间使用下划线分割
类(Class)和Modules:首字母使用大写。例如:LineItem这样的类名。
Rails使用这样的命名约定并且作了扩展。首先假定数据库中表名和变量命名一样,采用全小写字母,并且单词中间使用下划线分割
,并且表明都是复数形式的,例如:orders,third_parties。同时,Rails假定文件的命名也使用小写和下划线。
Rails根据这些约定自动进行名字的转换,例如,你的程序里或许包含一个Model类来操作lineitem,你可以使用Rails的命名约定,
把这个类命名为LineItem,根据这个名字,Rails会作下面的推断:
数据库里的表名为line_items。
在app/models目录下有一个line_item.rb文件。
Rails的控制器(Controller)的命名有另外的约定,如果你的程序里有一个store的Controller,Rails会作下面的推断:
有一个类叫做StoreController,并且在app/controllers目录下有一个store_controller.rb文件。
在app/helpers目录中,有一个文件叫做store_helpers,里面的类名叫做StoreHelper。
在控制器对应的目录app/views/store来查找视图模板。
获得视图的输出,并且把他们转换到app/views/layouts目录下的store.rhtml或者store.rxml的布局模板中。
通常在ruby的代码中,我们使用require关键字来将一些文件中的类引入到当前的代码中,因为Rails知道文件名和类名之间的关系,
所以require关键字在Rails程序中不是必须的,在你引用一个不知道名字的类或者module的时候,Rails将根据命名约定将类名转换成文件名,并且加载这个文件,效果就象你通过名字引用一个model,然后这个model自动被加载到程序中。 就象你所看到的,这个模式在类被存储到session中时被打破了,在这种情况下我们要明确的声明他们,例如,我们在控制器(controller)里:
class StoreController < ApplicationController
model :line_item
在这里,命名规约还在使用,标记:line_item全部小写并且用下划线分开,这会使line_item.rb文件被加载,而这个文件中包含有
类LineItem。
2. 把控制器(controller)分组到模块中
现在,我们的所有的controller都放在app/controller目录下,有时候我们的controller可能比较多,为了不污染到顶层的命名空间(namespace),我们可以选择将某几个controller归组到一个单独的命名空间里。
对此,Rails有一个简单的约定,如果一个请求(request)包括了controller的名字,例如:admin/book,Rails会在app/controller/admin/目录下寻找名为book_controller的控制器,控制器名字的最后部分将会变换成name_controller.rb,并且将会从app/controller目录开始,根据请求的前半部分(这里是admin)来定位到子目录里。
想像一下我们的程序有这样的两组controller,admin/xxx,content/xxx,并且两组里面都有一个控制器book,这样在app/controller目录的两个子目录app/controller/admin和app/controller/content里都有一个book_controller.rb文件,里面又都有类BookController,如果Rails不作额外处理,将会造成冲突。
为了处理这种情况,Rails采取的办法是,在这两组controller的目录里的book_controller.rb文件中类的声明前添加控制器所在组
的名字,例如,admin目录里的book_controller.rb文件中的类声明是这样:
class Admin::BookController < ApplicationController
# ...
end
而content目录下的类声明是这样:
class Content::BookController < ApplicationController
# ...
end
这样,两个book_controller就可以被区分开了。
在web浏览器里对controller发出请求时,这样:
http://my.app/admin/book
在使用Rails的命令行生成controller的时候,直接在类名前加上组的名字就可以了,例如:
myapp> ruby script/generate controller Admin::Book action1 action2 ...
分享到:
相关推荐
### Rails 入门详细知识点解析 #### 一、环境搭建 在开始Rails的学习之旅之前,首先需要搭建一个合适的工作环境。以下为环境搭建的具体步骤: 1. **Ruby 版本**: - 官方推荐使用 Ruby 1.9.2 或更高版本,因为...
- **覆盖命名约定**:介绍如何覆盖默认的命名约定,以适应不同的需求。 - **CRUD:读写数据**:详细阐述如何使用ActiveRecord实现增删改查的基本操作。 - **数据验证**:讲解如何为模型添加验证逻辑,确保数据的一致...
**标题与描述**:为了更好地理解和使用Rails框架,本书还探讨了一些底层的技术细节,例如框架的启动过程、配置选项、命名约定等。 **详细说明**: - **启动过程**:从启动命令到Web服务器的整个过程进行了详细的...
4. **路由**:Rails的路由系统允许灵活地定义URL到控制器动作的映射,书中介绍了如何设置资源路由、命名路由和自定义路由规则。 5. **ActiveRecord**:详述了ActiveRecord是如何作为对象关系映射(ORM)层工作的,...
Ruby on Rails(简称Rails)是一个基于Ruby语言的开源Web应用框架,它遵循MVC(Model-View-Controller)架构模式,强调“约定优于配置”(Conventions over Configuration)和“Don't Repeat Yourself”(DRY,不要...
在Web开发领域,Rails以其高效、简洁的代码和“约定优于配置”的哲学吸引了众多开发者。通过深入理解"Advanced Rails",开发者可以掌握以下关键知识点: 1. **优化性能**:Rails应用在处理大量请求时可能会面临性能...
Rails的哲学强调“约定优于配置”和“Don't Repeat Yourself”(DRY)原则,使开发者能够快速构建功能丰富的Web应用。 在Ruby on Rails的源代码中,我们可以深入理解其内部工作原理,包括路由、数据库交互...
#### 三、Rails背景 Ruby on Rails是由Jason Fried和David Heinemeier Hansson共同创立的。起初是作为BaseCamp项目的内部工具,后来发展成为一个独立的Web开发框架。其设计理念受到了Java和PHP的影响,并逐渐成为Web...
Rails的哲学是“约定优于配置”,鼓励开发者遵循一套标准的命名和组织规则,从而提高开发效率。 在Rails的开发文档中,你可以找到以下关键知识点: 1. **Ruby基础**:首先,你需要对Ruby语言有一定的理解,包括其...
接着,详细解释了 Rails 所遵循的一些基本原则和理念,例如约定优于配置(Convention over Configuration, CoC)、干式原则(Don't Repeat Yourself, DRY)等。此外,还介绍了模型-视图-控制器(Model-View-...
例如,Rails中的控制器文件通常位于app/controllers目录下,且文件名需以Controller结尾,类名则遵循小写和下划线命名约定。例如,HelloWorldController.rb文件位于app/controllers目录下,并继承自...
Ruby on Rails是一种使用Ruby语言编写的开源Web应用框架,它遵循“约定优于配置”(Convention over Configuration)的理念,旨在帮助开发者快速而简单地创建、部署和维护网站。Rails for Zombies是一份面向初学者的...
Ruby on Rails,简称Rails,是基于Ruby编程语言的开源Web应用程序框架,它遵循MVC(模型-视图-控制器)架构模式,旨在提高开发效率和可读性,同时强调“约定优于配置”的原则。Rails的核心理念是“开发应该是一种...
Rails框架中,各个组件的位置和命名通常遵循一定的标准模式。比如,模型(Model)通常放置在`app/models`目录中,控制器(Controller)放置在`app/controllers`目录中,视图(View)则放在`app/views`目录下相应控制...
Rails最佳实践是提升代码质量和可维护性的关键,下面将详细介绍一些重要的Rails开发规范和技巧。 1. **DRY (Don't Repeat Yourself)**:DRY原则是Rails的核心哲学之一,提倡避免重复的代码。通过创建模块化、可重用...
本章节详细介绍了Rails应用的基本架构,包括三个核心组件:模型(Model)、视图(View)和控制器(Controller),即MVC模式。 **2.1 模型、视图与控制器** - **模型(Model)**:负责处理应用数据逻辑的部分,通常...
为了实现这一点,Rails遵循惯例,大量的功能都是通过遵循命名约定和约定的目录结构来实现的,这样在很多情况下,开发者不需要编写大量的配置代码。 书中提到Rails 4,这是Rails框架的一个版本。每个新版本的Rails...