美文网首页
rails 环境配置

rails 环境配置

作者: 风___________ | 来源:发表于2018-03-09 19:35 被阅读4次

ruby 的各种概念

环境配置

  • 工具配置
// 下载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. 正规方法:
# 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. 简单方法:(不正规)
# 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

相关文章

网友评论

      本文标题:rails 环境配置

      本文链接:https://www.haomeiwen.com/subject/ktaktftx.html