Ruby 入门

简单哲学、高生产力、精巧、自然语法、高可读性&可维护性
灵感来自: Lisp(难以读懂)、Perl和Smalltalk
初衷: 让程序员能够更快乐的写代码
动态语言: 更少的代码做更多的事,更敏捷的开发;执行效率比静态语言(Java、C++、etc.)慢,没有编译期可以检查类型错误(单元测试/TTD来解决)

Ruby语言推荐入门

  1. Ruby 学习
  2. 关于Ruby
  3. 20分钟体验Ruby
  4. Code School Try Ruby
  5. 其他语言与Ruby的对比,学过其他语言的再学习ruby有很大帮助

推荐学习网址

DSL

目前应用于DSL(Domain-specific language)非常成功。

成功的SDL函数库:

  • Rake构建工具
  • RSpec测试工具
  • Chef伺服器设定工具
  • Cucumber验收测试

RubyGems

Ruby的套件管理系统,简化安装以及管理Ruby函数库

也可以通过The ruby Toolbox来查找套件,按照热度排列的。

常用指令

1
2
3
4
5
6
7
8
9
gem -v #告诉你RubyGems 的版本
gem update --system #升级RubyGems的版本
gem install gem_name #安装某个套件
gem install gem_name --no-ri --no-rdoc #安装套件,不产生期RDoc和ri文件
gem list #列出安装的套件
gem update gem_name #更新最新版本
gem update #更新所有你安装的Gems
gem install -v xxx gemname #安装特定版本
gem uninstall gem_name #反安装

RoR(Ruby on Rails)

作者: David Heinemeier Hanson
2004年DDH将Rails从37sinals商业产品中独立开源出来
目标: 更少的代码,更多的功能,轻量&强大
特点: 社区活跃、轻量、开发周期短

  • 采用MVC模式
  • 内建支援单元测试和整合测试
  • 支持Ajax
  • 支持RESTful界面
  • 支持ORM机制
  • 支持HTML5、JQuery

指导原则

  • DRY(Don’t Repeat Yourself) 不要重复自己
  • 惯例胜于设定(预设好设定,不需要我们去设定细节)
  • REST – 最佳模式(Resources和标准的HTTP verbs来组织代码)

安装

介于国内网络环境,导致rubygems.org放在Amazon S#上面的资源文件间歇性连接失败,Fuxk!! 所以需要配置到taobao以后再试。

国内用户: 以下步骤切换到taobao提供的rubygems.org镜像(15分钟一次与官网同步)

1
2
3
4
5
6
7
$ gem sources --remove https://rubygems.org/
$ gem sources -a https://ruby.taobao.org/
$ gem sources -l
*** CURRENT SOURCES ***
https://ruby.taobao.org
# 请确保只有 ruby.taobao.org

开始安装rails

1
2
# 为了节省安装时间,不安装文件档--no-ri、--no-rdoc(文档google上查更方便,不是吗)
gem install rails --no-ri --no-rdoc

输入rails -v可以看到当前rails的版本

开始使用

I. 创建一个demo的案例:

1
rails new demo --skip-test-unit

由于rails new会用到bundle,而介于国内的墙,因此国内用户需要配置下淘宝提供的镜像:

1
bundle config mirror.https://rubygems.org https://ruby.taobao.org

II. 目录分析

创建demo以后,会出现一个demo文件夹,进入以后的目录结构:

档案/目录用途
Gemfile设定Rails应用程式会使用哪些Gems套件
README专案说明:你可以用来告诉其他人你的应用程式是做什么用的,如何使用等等。
Rakefile用来载入可以被命令列执行的一些Rake任务
app/放Controllers、Models和Views档案,接下来的内容主要都在这个目录。
config/应用程式设定档、路由规则、资料库设定等等
config.ru用来启动应用程式的Rack伺服器设定档
db/资料库的结构纲要
doc/用来放你的文件
lib/放一些自定的Module和类别档案
log/应用程式的Log记录档
public/唯一可以在网路上看到的目录,这是你的图档、JavaScript、CSS和其他静态档案摆放的地方
bin/放rails这个指令和放其他的script指令
test/单元测试、fixtures及整合测试等程式
tmp/暂时性的档案

III. 启动服务器

1
2
#rails server可以间写为rails s
bin/rails server

屏幕上出现:

1
2
3
4
5
6
7
=> Booting WEBrick
=> Rails 4.2.3 application starting in development on http://localhost:3000
=> Run `rails server -h` for more startup options
=> Ctrl-C to shutdown server
[2015-07-26 20:00:19] INFO WEBrick 1.3.1
[2015-07-26 20:00:19] INFO ruby 2.2.2 (2015-04-13) [x86_64-darwin14]
[2015-07-26 20:00:19] INFO WEBrick::HTTPServer#start: pid=23454 port=3000

说明已经运行在3000端口了:http://localhost:3000

IV. 终端服务器

1
2
#开发模式下,除修改config或vender目录下的文件,其他都不用重启,正式上限模式,任何文件修改都需要重新启动服务器
<Ctrl> + <C>

Hello World

基于Rails的MVC框架,由于Hello World不需要数据支持,因此我们只需要涉及到C-V

I. 创建一个welcome:

1
2
#rails generate 可以简写未rails g
bin/rails generate controller welcome

II. 对页面进行路由:

编辑config/routes.rb文件,新增一行:

1
2
3
4
5
Rails::Application.routes.draw do
# 将http://localhost:3000/welcome/say_hello这样的网址对应到welcome Controller的say Action上。
get "welcome/say_hello" => "welcome#say"
...
end

III. 在Control中添加sayAction已经在View上也添加

编辑app/controllers/welcome_controller.rb,加入一个say方法

1
2
3
4
class WelcomeController < ApplicationController
def say
end
end

编辑app/views/welcome/下创建对应Action名称(say)的文件:say.html.erb(html表示是HTML格式文件),(erb表示是ERb样式),添加内容如下:

1
<h1>Hello, World!</h1>

IV. 验证

打开地址http://localhost:3000/welcome/say_hello:

进一步学习

View相关

1
2
3
4
#link_to 是Rails内部方法用于输出超链接,welcome_say_hello_path输出地址/welcome/say_hello
<p><%=link_to 'Hello!', welcome_say_hello_path %></p>
#root_path 首页地址(http://localhost:3000/)
<p><%=link_to 'Home', root_path %></p>

Model相关

Rails数据设定文件是: config/database.yml
Rails内建数据库SQLite是一套非常轻量的数据库文件(资料库)而已,流量大的线上环境不合适,用来开发和测试非常好用。

YAML

这里的配置文件是YAML格式文件,YAML是可读性高的表达配置文件的存档格式。

严格要求:

  1. 缩进
  2. 冒号后面必须有空格

注意: 数字与换行尽量用引号,避免出错(一串数字会被解析成Fixnum)

三个模式在config/database.yml配置:
  • development 开发模式
  • test 测试模式,用在自动测试时,由于test的数据库会被删除,因此不要配置成development的与production
  • prodution正式上线的模式
1
2
3
4
5
#建立资料库,会在db/目录下建立development、test的SQLite3的存档
bin/rake db:create
#Rake是Ruby的命令工具,这个命令列出rake的所有可用指令
rake -T
scaffold鹰架功能

会自动生成一组Model、Views、Controller代码,完成一个简易的C(Creat)R(Read)U(Update)D(Delete)的资料库

1
2
3
4
5
# 利用scaffold功能,建立person表,包含字段name,bio,birthday
bin/rails g scaffold person name:string bio:text birthday:date
# 通过迁移档,来生成资料页(http://localhost:3000/people),支持rud
bin/rake db:migrate
目录说明
db/migrate/20141021135430_create_people.rb用来建立people资料库资料表的Migration(你的档案开头名称会有不同的时间)
app/models/person.rbperson model档案
app/controllers/people_controller.rbpeople controller档案
app/views/people/index.html.erb用来显示所有文章的index页面
app/views/people/edit.html.erb用来编辑文章的页面
app/views/people/show.html.erb用来显示特定一篇文章的页面
app/views/people/new.html.erb用来新增文章的页面
app/views/people/_form.html.erb用来显示编辑和新增文章的表单局部(Partial)样板
app/helpers/people_helper.rb可在文章Views中使用的Helper方法
config/routes.rb设定URL路由规则的档案,scaffold再此新增了一行resources :people
app/assets/stylesheets/scaffold.css.scssScaffold鹰架提供的样式档案
app/assets/stylesheets/people.css.scsspeople的CSS样式档案
app/assets/javascripts/people.js.coffeepeople的JavaScript档案

config/routes.rb相关

1
2
3
4
5
6
Rails::Application.routes.draw do
...
#设置wecome为首页
root :to => "welcome#index"
...
end

错误排查

NameError

读取了一个不存在/没有初始化过的成员变量

SyntaxError:unexpected$end

多了或少了end关键字,可以单独用ruby -w去执行发生错误的代码,例如ruby -w app/controller/welcome_controller这样会打开Ruby的警告模式


参考资料


Jacksgong wechat
欢迎关注Jacks Blog公众号,第一时间接收原创技术沉淀干货。