环境配置
- 工具配置
// 下载python3
brew search python3
brew install python3
// 安装python3的第三方包管理工具pip3
// https://pip.pypa.io/en/stable/installing/#do-i-need-to-install-pip 文件另存为.py
python3 get-pip.py
// pip3安装第三方包
pip3 install -r requirements.txt
// pip3 freeze > requirements.txt
// 下载gpg(文件加密)
brew install gnupg gnupg2
curl -sSL https://rvm.io/mpapis.asc | gpg --import -
gpg --keyserver hkp://keys.gnupg.net --recv-keys 409B6B1796C275462A1703113804BB82D39DC0E3 7D2BAF1CF37B13E2069D6956105BD0E739499BDB
// 安装rvm (rvm是ruby的一个版本环境控制器)
\curl -sSL https://get.rvm.io | bash -s stable --ruby
// 安装ruby2.3
rvm install 2.3
// 切换至 ruby2.3
rvm use 2.3
// 安装 包管理
gem install bundler
cd /backend/trunk/
bundle install
- rails路由配置 (routes.rb)
get 'welcome/first'
get 'welcome/second'
# 根目录(welcome 控制器下的 first 活动)
root 'welcome#first'
# resource 方法(会自动生成welcome资源下所有的访问)
resource welcome
rails 命令
# 创建controller
rails generate controller welcome
# 删除一个controller
rails destroy controller welcome
# 创建controller同时创建first 和 second活动
rails generate controller welcome first second
# 查看工程路由信息
rake routes
# 创建model的migrate
rails generate model User name:string descrip:text time:datetime
# 根据migrate 创建表
rake db:migrate
# 创建文件
touch app/views/user/new.html.erb
实例如下:
// 查看rails new 命令的参数
rails help new
// 创建一个名字为blog的rails项目
rails new blog --skip-bundle
// 通过bundle安装依赖的gem文件
bundle install
// rails generate 创建一个post模型:后面是他的字段
rails generate model Post title:string content:text author:string publish_at:datetime
// 下面是上述命令执行的结果,创建了几个文件
invoke active_record
create db/migrate/20180310080403_create_posts.rb
create app/models/post.rb
invoke test_unit
create test/models/post_test.rb
create test/fixtures/posts.yml
// rake命令通过生成的(db目录下的)migrate来对数据库进行创建
rake db:migrate
// 下面是rake命令执行结果
== 20180310080403 CreatePosts: migrating ======================================
-- create_table(:posts)
-> 0.0016s
== 20180310080403 CreatePosts: migrated (0.0017s) =============================
// rails c进入到命令行查看是否创建成功Post类
rails c
Loading development environment (Rails 4.2.7.1)
2.3.4 :001 > Post
// 下面是结果,显示有这个类(子段名以及类型)
=> Post(id: integer, title: string, content: text, author: string, publish_at: datetime, created_at: datetime, updated_at: datetime)
// 创建一个包含index动作的Welcome控制器
rails generate controller Welcome index
// 下面是上述代码执行结果
create app/controllers/welcome_controller.rb
route get 'welcome/index'
invoke erb
create app/views/welcome
create app/views/welcome/index.html.erb
invoke test_unit
create test/controllers/welcome_controller_test.rb
invoke helper
create app/helpers/welcome_helper.rb
invoke test_unit
invoke assets
invoke coffee
create app/assets/javascripts/welcome.coffee
invoke scss
create app/assets/stylesheets/welcome.scss
使用 rails 脚手架工具生成完整资源套件(模版啥的):
# 使用脚手架工具生成所有需要的配置信息(controller model view 等)
rails generate scaffold Post content:text
牢牢记住各个action动作默认做的事情:
# 获取模型列表
def index
@posts = Post.all
end
# 获取详情(根据params id字段查询并且用show.html.erb显示)
def show
# 此方法实际上是下面代码 隐式实现的
# @posts = Post.find params[:id]
end
往已存在的rails model增加字段
往已存在的User中增加password字段
- 正规方法:
# 1. 创建一个migration 规范名字(直接生成一个写好的migration文件)
rails generate migration add_user_id_to_posts user_id:id
# 自动创建好的文件
class AddNikeNameToUsers < ActiveRecord::Migration
def change
add_column :users, :nike_name, :string
end
end
# 2. rake一下migration文件
Mac-mini-2:learnproject jing$ rake db:migrate
# 1. 创建一个migration 名字随便起
rails g migration AddColumnPasswordToUser
# 结果:create db/migrate/20180314055455_add_column_password_to_user.rb
# 2. 编辑migration 文件(按照需求编辑migration文件)
class AddColumnPasswordToUser < ActiveRecord::Migration
def change
add_column :users,:password,:string
end
end
# 3. rake一下migration文件
rake db:migrate
- 简单方法:(不正规)
# 1. 直接修改 create_user.rb migrate文件
class CreateUsers < ActiveRecord::Migration
def change
create_table :users do |t|
t.string :name
t.string :email
t.string :password
t.timestamps null: false
end
end
end
# 2. 然后去数据库中添加一列 password,不需要rake migrate文件
关联数据
users表 和posts表 关联
# 1. 新加一个id字段
rails generate migration add_user_id_to_posts user_id:id
rake db:migrate
# 2. rails model关联(belongs_to 和 has_many )
# 一对多
class Post < ActiveRecord::Base
belongs_to :user
end
# 多对一
class User < ActiveRecord::Base
has_many :posts
end
# 3. post save方法时候
@post.user_id = session[:user_id]
@post.save
# 然后就可以这样获取user
post.user.userName
# 多对多关系建立
# 1. has_and_belongs_to_many 关键字
class Post < ActiveRecord::Base
has_and_belongs_to_many :categories
end
# 2. create_join_table: categories,:posts 建立一个关联表
rails g migration create_join_table_for_posts_and_categories
# 编辑
class CreateJoinTableForPostsAndCategories < ActiveRecord::Migration
def change
create_join_table :categories,:posts
end
end
# 3. 更新
rake db:migrate
单元测试
# 运行测试文件命令
bundle exec rake test
# test如下
class UserControllerTest < ActionController::TestCase
test "should get new" do
get :new
assert_response :success
end
end
model相关
# 手动添加数据到数据库
Mac-mini-2:my_custom_blog jing$ rails c
Loading development environment (Rails 4.2.7.1)
2.3.4 :001 > Post.create(title:'first post',content:'content of first post',author:'jing',published_at:Time.now)
# 序列化model的属性
class Post < ActiveRecord::Base
serialize :tags
end
# 手动修改数据库记录
p = Post.first
p.tags = ['blog','post']
p.save