Ruby on Rails website 的基础是 请求-返回 循环。





首先是浏览器请求服务器,





第二步,Second, in our Rails application, the route takes the request and finds the right Controller and method to handle the request.





第三步,控制器拿到相关数据并发给View模块。





最后,View模块把数据打包好,并且发回给浏览器显示。

-----

搭建开发环境:

  • Creat rails file package: rails new my-app
  • Install Ruby gems
  • Making a controller called pages
  • 在routes.rb文件中,Create a route
  • Create the View

1. Creat rails file package

操作 Rails 用的commands叫做Generator, 在Terminal里,使用如下命令可以新建一个rails app:

rails new my-app

rails就会建立一系列的站点文件。

然后我们在浏览器里输入:localhost:8000就能访问rails建立的第一个web 站点:

Let's learn about the files that you generated.来看看我们建立了哪些文件:

Rails is made up folders that hold our code:

   app - Where our Models, Views and Controllers are. It is where most of our Rails code will go.

   config - Where we find our routes. They handle requests from the browser.

   db - Where we change the state of our database.

   Gemfile - Where our gems are. Gems add special features to our Rails app.



可以参考下图:

2. Install Gem

To run Rails we also need to install Ruby gems. Gems are prepackaged code that make sure our application runs smoothly. They can also add new features.

We add gems through a simple command called bundler. Bundler takes the gems in our Gemfile, an editable file, and stores them in Gemfile.lock, an uneditable file.

To run bundler, we type the following in our terminal:

bundle install

3. Making a controller called pages

In the Request-Response Cycle, we learned that when a user makes a request in the browser, the route handles that request and passes it to the right Controller.

一个route路由来处理浏览器的request,请求。发给Controller

We’ll start building our app by making a Controller called Pages. Controllers decide what information our application needs through methods. Our Pages Controller will be in charge of decisions for the home page of the Etsy app.

How do we generate a Controller?

If we want to generate a Controller called Pages, we enter the following in the terminal:

rails generate controller Pages

Notice that Controller names are always plural.

现在我们就有了pages controller(app/controllers/pages_controller.rb),控制器是通过methods来决策的,这些methods跟前面用的ruby methods是相似的,同时,它们是写在我们创建的Pages Controller里的。



Controller methods主要作用于两方面:

a -- 告诉我们的app,应该显示哪个view

b -- 准备信息,让view可以轻易地显示它。



如果是静态的app,methods就简单了,它只需要告诉Rails哪个view to show.例如:

    def home

    end

这就是告诉controller来render home view. 如果methods里有内容,就会执行它们。这里我们只需要def home 和 end ,Rails就知道是要call the home view.

在app/controllers/pages_controller.rb文件中:

class PagesController < ApplicationController
def home
end
end

操作:

1.

In your Pages Controller, pages_controller.rb, Define a method called def home. You do not need a method body. Hit Run.

2.

In your browser visit localhost:8000/pages/home to see what was created. You can expect to get a Routing Error.

=====================

4. 在routes.rb文件中,Create a route

上一步完成后,我们得到了一个Routing Error的错误,我们前面看到了,来自浏览器的request 是需要一个route进行分发的,分发给controller进行处理。所以我们现在要增加一个routes.rb的文件来补充这个route.



在rails 中,Routes就像app的门一样,来保证正确的分发请求,从而让我们browser 拿到正确的view 返回。



尽管Routes 是我们的第一站,但是我们还是要先拿到controller里的名字和method名字才能写routes。



在routes.rb文件中,we create a route like this, under

Rails.application.routes.draw do:

get 'pages/home'

这里,pages 指的就是controller pages.    home就是指的我们在Controller里定义的那个method的名字home。

在这个事儿里,我们还要创建一个根路径。根路径就是设置一个home page的路径,作为一个app的首页请求。这里, pages/home是我们的首页,所以我们建立的根路径就是:root ’pages#home' (We will also create a root route in this unique
case. A root route is a way to set a route as the home page of the application, or the 'root'. Since pages/home will be our home page, we'll create a root route like this:)

root 'pages#home'

然后在浏览器中再输入 localhost:8000  就能预览效果了。

routes.rb文件源码:

Rails.application.routes.draw do
get 'pages/home'
root 'pages#home'
end

5. Create the View

现在我们已经能够显示一个简单的主页了,不过这个页面只有一句话。我们建立了Controller & Routes, 下一步要Create View了:

Views用来处理用户看到的可见的显示。

Views是怎么来管理presentation的呢?

1.通过html来管理页面。

2.通过ERB - Embedded Ruby ,它是把ruby代码嵌入html页面的一种途径。We can use Ruby objects in our HTML files just as we do in plain Ruby.



由于Views使用了html and ERB,所以View的files总是后缀为.html.erb



在.html.erb文件中,主要有2个categories of ERB: 一个是只在我们代码里显示的code,一种是显示在app里的live code.



如果我们写成:

  <% "goodbye world" %>

    就只有后台能看到。



如果我们写成:

  <%= "hello world" %>

    it will appear live in on our app.就一个=号的区别。



这里这个例子是这样的:

1. 在pages_controller.rb文件中,加入一个method: erb_demo

class PagesController < ApplicationController
def home
end
def erb_demo
end
end

2. 在routes.rb文件中,加入一个route:pages/erb_demo

Rails.application.routes.draw do
get 'pages/home'
root 'pages#home'
get 'pages/erb_demo' #浏览器就可请求localhost:8000/pages/erb_demo,不过,代码里pages/erb_demo是:ControllerName/MethodsName
end

3. 在erb_demo.html.erb文件中,加入两行categories of ERB, 一个不可见,一个可见。

  <%= "This is the erb demo template." %>
<% "goodbye world" %>
<%= "hello world" %>

4. 最后在浏览器中请求: localhost:8000/pages/erb_demo    ,可以得到:

至此,一个ruby环境的搭建,建立一个简单的ruby app来显示一个网页,就搞定了。

Ruby学习笔记2 : 一个简单的Ruby网站,搭建ruby环境的更多相关文章

  1. blfs(systemv版本)学习笔记-制作一个简单的桌面系统

    我的邮箱地址:zytrenren@163.com欢迎大家交流学习纠错! 大概思路: lfs(系统)+xorg(驱动)+i3-wm(窗口+桌面)+lightdm(显示管理器+登录管理器) 链接: lfs ...

  2. Oracle学习笔记:一个简单的行转列例子

    一个简单的行列转换例子,原始数据. create table temp_cwh_student ( name ), subject ), score ) ) select * from temp_cw ...

  3. cpp学习笔记 1一个简单的小程序以及一些的知识点

    今天买的cpp到了从今天開始又一次学习cpp如今发现学校发的书真的不怎莫样. <em>#include<stdio.h>//预处理命令 int main()/*第一个被调用的函 ...

  4. Spring学习笔记--声明一个简单的Bean

    spring依赖的maven dependencyhttp://mvnrepository.com/artifact/org.springframework 在pom.xml中添加如下依赖: < ...

  5. Windows程序设计学习笔记(1):一个简单的windows程序

    <Windows程序设计>(第五版)(美Charles Petzold著) #include<windows.h> LRESULT CALLBACK WndProc(HWND, ...

  6. ROS学习笔记11-写一个简单的服务和客户端(C++版本)

    本文主要来源于:http://wiki.ros.org/ROS/Tutorials/WritingServiceClient%28c%2B%2B%29 写一个服务节点.在创建消息和服务中,我们创建了一 ...

  7. ROS学习笔记10-写一个简单的订阅者和发布者(C++版本)

    本文档来源于:http://wiki.ros.org/ROS/Tutorials/WritingPublisherSubscriber%28c%2B%2B%29 写发布者节点如前所述,节点是连接到RO ...

  8. Ruby学习笔记4: 动态web app的建立

    Ruby学习笔记4: 动态web app的建立 We will first build the Categories page. This page contains topics like Art, ...

  9. ruby学习笔记(1)-puts,p,print的区别

    ruby学习笔记-puts,p,print的区别 共同点:都是用来屏幕输出的. 不同点:puts 输出内容后,会自动换行(如果内容参数为空,则仅输出一个换行符号):另外如果内容参数中有转义符,输出时将 ...

  10. ASP.NET MVC Web API 学习笔记---第一个Web API程序

    http://www.cnblogs.com/qingyuan/archive/2012/10/12/2720824.html GetListAll /api/Contact GetListBySex ...

随机推荐

  1. 【java】函数重载

    重载概念(Overloading): 在同一个类中,允许存在一个以上的同名函数,主要他们的参数个数和参数类型不同即可 重载特点: 与返回值无关,只和参数类型和参数个数有关系(重载只和参数列表有关系) ...

  2. Centos7安装WPS和截图工具shutter

    centos7安装WPS 1..在wps官网上下载rpm安装包 2..rpm包安装命令 yum install xxx[安装包的名字] 注意:执行此项命令需要root权限 3.安装完成后即可使用 Ce ...

  3. Excel技巧--使用规划求解

    当我们需要求在有限预算下可以购买的商品数量时,我们就可以使用“规划求解”功能.如上图,在1000元的预算目标内,我们能购买左图中的各书籍多少本.而这些数量,就可以使用“规划求解”来获取答案. 1.实际 ...

  4. mysql5.7 主从同步

    一:进行bin-log日志配置 1设置bin-log日志 [mysqld] log-bin=//路径  #<===红色的加粗的省去 server-id = 1    #主库 2.检查配置登录数据 ...

  5. 创建virtualenv虚拟环境

    这个部分知识我在之前的随笔里记过笔记. 传送门:http://www.cnblogs.com/0bug/p/8598458.html 本文只演示Windos下virtualenv环境的使用: 首先,确 ...

  6. 关于Dubbo面试问题

    一.默认使用的是什么通信框架,还有别的选择吗? 默认也推荐使用netty框架,还有mina. 二.服务调用是阻塞的吗? 默认是阻塞的,可以异步调用,没有返回值的可以这么做. 三.一般使用什么注册中心? ...

  7. C++进阶--模板及关键字typename

    //############################################################################ /* * 模板介绍 */ //函数模板 t ...

  8. 查看app日志的方法

    可以打开SDk里面的 ddms.bat 查看日志 路径: android-sdk-macosx/tools/ddms SDK下载的地址: http://www.androiddevtools.cn/ ...

  9. Hive - ORC 文件存储格式【转】

    一.ORC File文件结构 ORC的全称是(Optimized Row Columnar),ORC文件格式是一种Hadoop生态圈中的列式存储格式,它的产生早在2013年初,最初产生自Apache ...

  10. android adb push 命令

    1.获得root权限:adb root 2.设置/system为可读写:adb remount 3.将PC机上文件复制到手机:adb push 文件名  /system/lib