rails_了解您的Rails应用程序结构[初学者指南]

rails

因此,您正在学习Rails。 您正在学习一个教程,必须输入: rails new my_app和voilà! 您已经准备好第一个Rails应用程序,可以开始使用它了。

可是等等! 您刚刚创建的文件和文件夹是什么?

正如奇妙而神奇的Rails一样,了解从何处开始工作也可能具有挑战性。 即使您正在学习教程,您也无法回答所有关于为什么要对所有这些文件进行更改的问题。

在本文中,我将 用简单的英语 解释

  • Rails应用程序的结构
  • 您的应用程序包含哪些关键元素
  • 这些元素如何相互链接
  • 在终端中运行的重要命令

阅读本文后,您将在构建第一个应用程序并真正按照自己的操作进行时更有信心。

免责声明:此文章是针对初学者的,一些概念将得到简化以简化理解。 如果您想更深入地了解它们,我仍将提供指向专门资源的链接。

MVC

您需要了解的第一个概念是模型视图控制器结构。 一旦掌握了窍门,您就在轨道的另一端( 获得我聪明的文字游戏? )。

您可以将MVC看作是生活在Web应用程序中的一家小型公司。 它处理通过不同部门(模型,视图和控制器)的信息流,以提供出色的客户体验。

如您所见,当您使用浏览器访问网站时,MVC会处理过程的每个部分。 借助MVC,您可以订阅网站,登录帐户,注销等等。

让我们一步一步地回顾一下Web应用程序内部发生的过程:

  1. 您要创建一个Facebook帐户。 您在浏览器中打开该网站。
  2. 您必须先注册,然后填写信息,然后单击“注册”按钮。
  3. 路由器收到指令。 他是负责接听所有来电到公司(网站)并将他们重定向到控制人员的人。
  4. 该人在财务主任办公室工作。 接听电话时,她从路由器听到您要创建一个新帐户。
  5. 财务负责人女人看着她的电话簿,并拨打负责呈现该页面的View员工的电话号码。
  6. View员工收到Controller女士的指示,以通过浏览器向您显示该网页。 你准备好了。
  7. 您输入用户名和密码,然后按Enter。
  8. 该过程再次开始:路由器呼叫控制器办公室,但是这次呼叫新员工,即登录办公室的负责人。
  9. 该控制员不会立即致电“查看”人员:他必须首先检查您是否被允许登录。
  10. 因此,主计人员从样板办公室打电话给天才女孩。 在数据库部门的老太太的帮助下,她是负责处理公司中所有信息的人。
  11. 天才女孩检查您的凭据并运行一些验证以确保您被授权。
  12. 确定您的身份后,她会致电财务总监办公室的那个人,让他知道您可以离开。
  13. 然后,Controller致电View办事处的另一个人,指示他们在浏览器中呈现一个新页面,即您的个人资料页面。

和presto! 这就是基于MVC结构(使用Rails或其他技术)的网站内部发生的情况。 一切都在几秒钟内完成!

Rails应用程序中的MVC

您可能会想:“ 这个MVC是多么出色的公司! 但这与我的应用有什么关系?”

好吧,该应用程序 公司。 而且您即将成为首席执行官,因此您最好将注意力放在您的工作上!

就像您在启动第一个应用程序时注意到的那样,项目中内置了许多不同的文件夹和文件。 这些文件代表您的应用程序的MVC,您将必须使用它们来使整个系统按您希望的方式工作。

最后,我将为您提供一些链接,这些链接将向您展示如何在将来继续使用Rails构建应用程序。

那么我们在这个Rails应用程序的目录中寻找什么

如上图所示,您的应用程序在主目录中有很多文件夹和文件。 您最常使用的文件夹是app文件夹。

应用文件夹

我们应该从查看应用程序文件夹开始。 它包含与我们一直在讨论的MVC相关的所有文件。 看看里面每个文件夹的注释。

现在看来似乎不难理解,对吧? 如您所见,一切结构都很好,您只需要知道如何阅读即可。

一旦您的应用开始增长,每个MVC文件夹将具有许多文件,它们将存储与您网站的不同部分相关的不同控制器,模型或视图。

让我们深入研究app文件夹:我们将专注于MVC目录:

  1. 楷模
  2. 控制器
  3. 观看次数

模型的文件夹

创建应用程序时,您将创建的第一个元素是Model 。 一个应用程序可以具有多个模型! 这取决于你想如何存储的信息。

请记住,模型负责处理您网站内的数据。 例如:如果您正在构建博客,则想存储与用户,帖子以及这些帖子的评论有关的信息。

另外,您希望该信息可以访问和组织,以使其永远不会混淆。 这就是模型的用途,您将需要一个用户,发布和评论模型,因为它们是完全不同的东西,具有自己的规范。

在每个模型文件中,您将(在开头)包括:

  1. 验证 决定要在数据库中存储什么以及如何存储(例如,避免用户名为空)。
  2. 应用程序不同模型之间的关联 (以检查哪个用户发布了一篇文章,或一篇文章有​​多少条评论)。

重要命令: rails generate model Name

*型号名称必须为单数

控制器文件夹

创建模型后,您需要构建控制器来管理应用程序内部的通信(记住MVC工作流程以及所有事物如何通过控制器)。

每个模型都有一个关联的控制器文件。 例如,在您的博客应用中,您将具有一个控制用户模型的users_controller.rb文件。 该文件包括与该模型有关的所有方法(操作)(请参阅CRUD )。

与控制器文件有关的一些约定和技巧是:

  1. 控制器名称与它控制的模型相同,但以复数形式表示。
  2. 每个控制器方法在route.rb文件中都有其对应的路由。 这样可以使应用正常运行(记住路由器会调用控制器)。 当我们进入config文件夹时,将对此进行更多介绍。
  3. 控制器内的几乎所有方法都呈现一个View。 方法的名称和视图文件必须匹配,以便Rails可以在用户执行操作时显示页面。
  4. user_params方法用于安全地传递与用户关联的参数(名称,电子邮件,密码),并且应为私有。

重要命令: rails generate controller name

视图的文件夹

您将创建的MVC的最后一个元素是视图。 如果您了解前端的基础知识,则在此部分中将包含构成页面HTML文件。

使用应用程序的视图时,有一种Rails 方式可以组织视图文件夹内,其他文件夹内的文件( folderception ):

  1. 布局文件夹包含与您网站的总体结构有关的所有HTML文件。 例如,您要在此处放置导航栏文件。
  2. 与模型相关的文件必须存储在以其命名的文件夹内(例如,用户模型的视图位于users文件夹内)。 注意多元性。
  3. 有一个共享文件夹,其中包含在网站的不同页面(部分)中使用的视图。

Rails的一个很酷的功能是能够将HTML文件分离为partials 。 当您要在网站的不同视图中使用相同的模板并使内容保持干燥时,此功能非常有用。 这些文件以“ _”开头。

关于使用Rails创建应用程序的另一个有趣的部分是,您创建HTML文件是动态的。 这些文件将包含嵌入式ruby 文件扩展名为.html .erb ),使您可以在HTML设计中合并变量(例如,当您要显示用户名时)。

这就是Rails应用程序MVC架构的基础。 但是,如果您不能正确连接它,那么这一切都不重要。 因此,您需要设置路线。

您可以通过以下方式生成控制器时创建视图的文件: rails generate controller name view_name view2_name

路线文件

在config文件夹中,您可以找到多个文件来调整Rails应用程序的行为,并添加要在应用程序启动时运行的其他代码。

首先,您将在此处使用的唯一文件是route.rb 。 将此视为公司的电话指南。 您的应用程序将检查此文件以调用正确的控制器并显示正确的视图。

您将在应用程序上创建的路由基于使用以下HTTP请求的RESTful原则:获取,放置,发布和删除。

在路由文件中,您将为应用的每个部分创建正确的联络人 。 检查上面的图像。 在第10和11行中,您声明,当用户进入 / signup页面时,他们将被路由到User Model方法,并且当他们单击signup按钮时,他们将使用内部的create方法发布信息。 用户模型

看一下图像的最后一行。 这是使用rails:resources:model声明应用程序中所需的所有路由的最简单方法。 此行将创建到模型的所有RESTful路由。

提示:请记住在创建Controller之后立即设置路线,否则在尝试打开页面时会遇到很多错误(因为我们不知道要呼叫谁来显示视图)。

在对Rails应用程序进行了广泛的概述之后,使用文件时应该会感到更自在。

在查看应用程序目录时,您会不会感到不知所措? 我希望本文对理解Rails的工作原理有所帮助。

需要更多帮助吗? 随时在帖子中添加评论,我很乐意回答您的问题!

记得在我的社交媒体上关注我:

您要检查的资源:

翻译自: https://hackernoon.com/understanding-your-rails-application-structure-r8w32xj

rails

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值