레일스 걸스 앱 튜토리얼

Created by Vesa Vänskä, @vesan

미리 레일스를 설치해야 합니다. 설치 가이드 링크로 가서 참고하세요.

툴을 살펴봅니다.

 

텍스트 에디터

 

터미널 (윈도우즈에서 명령행 프롬프트)

  • 터미널에서 레일스를 서버로 실행하며 명령어를 실행합니다.

 

웹브라우저

  • (파이어폭스, 사파리, 크롬) 여러분이 만든 애플리케이션을 보여줍니다.

Important

여러분이 사용하는 컴퓨터의 운영체제에 따라 안내사항을 선택하도록 합니다. - 윈도우즈 커뮤터에서 실행하는 명령어는 맥과 리눅스와 다릅니다. 따라하면서 실행할 명령어 테두리 아래에서 운영체제를 윈도우즈와 기타 중에서 선택할 수 있습니다. 클라우드 서비스(예. Codenvy)를 사용하는 경우, 윈도우즈 컴퓨터를 사용하는 사람도 리눅스 명령어를 실행해야합니다.

1.Creating the application

레일스 앱 이름을 railsgirls으로 새로 만들겠습니다.

먼저, 터미널을 열겠습니다:

다음, 터미널에서 아래와 같이 명령어를 키보드로 입력합니다:

mkdir projects

projects라는 이름의 디렉토리가 있는지 확인하려면 list 명령어를 실행합니다: ls. projects라는 디렉토리를 화면에 출력됩니다. 그럼 위치를 projects 폴더로 이동하겠습니다:

cd projects

ls 명령어를 실행해보면 디렉토리가 비어있습니다. 그럼 아래와 같이 railsgirls 라는 이름으로 앱을 새로 만들겠습니다:

rails new railsgirls

명령어 실행 결과 railsgirls 폴더에 앱을 새로 만듭니다. 레일스 앱 폴더로 이동하겠습니다:

cd railsgirls

이동한 디렉토리에서 ls 명령어를 실행하면 appconfig 폴더가 있습니다. 레일스를 서버로 실행합니다:

rails server
mkdir projects

projects라는 이름의 디렉토리가 있는지 확인하려면 list 명령어를 실행합니다: dir. projects라는 디렉토리를 화면에 출력됩니다. 그럼 위치를 projects 폴더로 이동하겠습니다:

cd projects

dir 명령어를 실행해보면 디렉토리가 비어있습니다. 그럼 아래와 같이 railsgirls 라는 이름으로 앱을 새로 만들겠습니다:

rails new railsgirls

명령어 실행 결과 railsgirls 폴더에 앱을 새로 만듭니다. 레일스 앱 폴더로 이동하겠습니다:

cd railsgirls

이동한 디렉토리에서 dir 명령어를 실행하면 appconfig 폴더가 있습니다. 레일스를 서버로 실행합니다:

rails server

브라우저 주소창에 http://localhost:3000 입력합니다. 클라우드 서비스(예. Codenvy)를 사용한다면 미리보기 기능을 사용합니다(설치 가이드 참고).

“Yay! You’re on Rails!” 페이지가 나타납니다. 새로운 앱을 오류없이 만들었습니다.

레일스 서버를 실행하였기 때문에 터미널에서 깜빡이는 프롬프트가 사라졌습니다. 아래와 같이 보입니다:

$
>

명령행 프롬프트가 보이지 않아서 다른 명령어를 실행할 수 없습니다. cd 명령어를 실행해봐도 꿈쩍하지 않습니다. 정상으로 돌아가려면 다음과 같이 합니다:

터미널에서 Ctrl+C 를 치고 서버를 종료합니다.

Coach: 명령어를 하나씩 설명하세요. 실행결과 무엇을 만들었나요? 서버가 무엇을 하나요?

2.Create Idea scaffold

이번에는 아이디어(idea)를 대상으로 아이디어 전체 목록을 나열하고 추가 삭제 수정하고, 아이디어 하나를 보여주는 코드를 한번에 만들어주는 레일스 스캐폴딩을 사용하겠습니다.

Coach: 레일스 스캐폴딩은 무엇인가요? (명령어, 모델 이름, 데이터베이스 테이블, 이름을 짓는 규칙, 속성과 타입 등을 설명합니다.) 마이그레이션은 무엇이고 마이그레이션이 왜 필요한가요?

rails generate scaffold idea name:string description:text picture:string

스캐폴드는 프로젝트 디렉토리에서 파일을 새로 만듭니다. 하지만 제대로 동작하려면 명령어를 몇개를 실행하여 데이터베이스를 업데이트하고 서버를 재시작해야합니다.

rails db:migrate
rails server

브라우저 주소창에 http://localhost:3000/ideas 입력합니다. 클라우드 서비스(예. Codenvy) 사용자는 미리 보기 주소에 ‘/ideas’ 를 붙입니다. (설치 가이드 참고).

화면에 보이는 아무 링크나 클릭해보고 실행결과를 봅니다.

3.Design

Coach: HTML과 레일스의 관계를 설명하세요. 뷰에서 HTML는 어느 파트이고 임베디드 루비(ERB)는 무엇인가요? MVC는 무엇이고 서로 어떤 관련이 있나요?(모델과 컨트롤러가 HTML 뷰를 생성하는데 맡은 역할)

앱은 아직까지 밋밋해보입니다. 좀 꾸며보겠습니다. 트위터 부트스트랩 프로젝트를 사용하여 매우 쉽게 프로젝트를 꾸며보겠습니다.

텍스트 에디터로 app/views/layouts/application.html.erb 파일을 편집합니다.

<%= stylesheet_link_tag    'application', media: 'all', 'data-turbolinks-track': 'reload' %>

줄 위에

<link rel="stylesheet" href="//maxcdn.bootstrapcdn.com/bootstrap/3.0.3/css/bootstrap.css">
<link rel="stylesheet" href="//maxcdn.bootstrapcdn.com/bootstrap/3.0.3/css/bootstrap-theme.css">

를 넣고 아래와 같은 줄을

<%= yield %>

다음과 같이

<div class="container">
  <%= yield %>
</div>

수정합니다. 레이아웃에 네비게이션 바와 푸터를 붙이겠습니다. <body> 태크 아래에

<nav class="navbar navbar-default navbar-fixed-top" role="navigation">
  <div class="container">
    <div class="navbar-header">
      <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse">
        <span class="sr-only">Toggle navigation</span>
        <span class="icon-bar"></span>
        <span class="icon-bar"></span>
        <span class="icon-bar"></span>
      </button>
      <a class="navbar-brand" href="/">The Idea app</a>
    </div>
    <div class="collapse navbar-collapse">
      <ul class="nav navbar-nav">
        <li class="active"><a href="/ideas">Ideas</a></li>
      </ul>
    </div>
  </div>
</nav>

와 같이 넣고 </body> 태그를 닫기 전에

<footer>
  <div class="container">
    Rails Girls 2017
  </div>
</footer>
<script src="//maxcdn.bootstrapcdn.com/bootstrap/3.0.3/js/bootstrap.js"></script>

넣습니다. 그럼 아이디어 테이블도 꾸미겠습니다. app/assets/stylesheets/application.css 파일을 아래와 같이 수정합니다.

body { padding-top: 100px; }
footer { margin-top: 100px; }
table, td, th { vertical-align: middle; border: none; }
th { border-bottom: 1px solid #DDD; }

파일을 저장하고 브라우저의 새로고침 버튼을 누르면 수정한 내용이 나타납니다. HTML과 CSS를 좀 더 바꿀 수 있습니다.

터미널에 자바스크립트나 커피스크립트가 잘못되었다는 에러메시지가 뜨는 경우, nodejs를 설치합니다. 레일스인스톨러를 사용하면 이 에러가 나타나지 않지만 gem install rails로 레일스를 설치한 경우 해당됩니다.

Coach: CSS와 레이아웃에 대해 간략히 설명하세요.

4.Adding picture uploads

레일스에 파일을 업로드하려면 소프트웨어 몇개를 설치해야 합니다.

프로젝트 디렉토리에서 Gemfile 이라는 파일을 텍스트 에디터로 아래와 같이 수정합니다.

gem 'sqlite3'

아래 줄에 다음과 같이 젬을 추가합니다.

gem 'carrierwave'

Coach: 라이브러리가 무엇이고 왜 유용한지 설명하세요. 오픈 소스 소프트웨어를 설명하세요.

터미널에서 Ctrl+C 치고 서버를 종료합니다.

터미널에서 아래와 같이 실행합니다:

bundle

그런 다음 업로드를 처리하는 코드를 짜겠습니다. 터미널에서 아래와 같이 실행합니다:

rails generate uploader Picture

레일스 서버를 실행하세요.

Note: 터미널을 하나 더 띄워서 레일스 서버를 종료하지 않고 실행할 수 있습니다. 그렇더라도 레일스 서버를 재시작합니다. 재시작해야 앞서 추가한 업로드 라이브러리를 사용할 수 있습니다.

업로더를 찾지 못하는 에러가 나타면 아래와 같이 추가합니다:

gem 'net-ssh'

app/models/idea.rb 파일을 수정합니다.

class Idea < ApplicationRecord

줄 아래에

mount_uploader :picture, PictureUploader

와 같이 추가합니다. app/views/ideas/_form.html.erb 파일을 수정합니다.

<%= form.text_field :picture, id: :idea_picture %>

를 아래와 같이

<%= form.file_field :picture, id: :idea_picture %>

바꿉니다. 브라우저에서 아이디어에 사진을 넣을 수 있습니다. 사진 파일을 업로드해보면 사진이 안보이고 파일 위치만 보입니다. 사진이 보이도록 수정하겠습니다.

app/views/ideas/show.html.erb 파일을 수정합니다.

<%= @idea.picture %>

를 아래와 같이

<%= image_tag(@idea.picture_url, width: 600) if @idea.picture.present? %>

바꿉니다. 브라우저의 새로고침 버튼을 눌르면 사진이 보입니다.

Coach: HTML를 간략히 설명하세요.

5.Finetune the routes

브라우저에서 http://localhost:3000 (클라우드 서비스를 사용하면 미리보기 주소)로 이동합니다. 첫 페이지가 “Yay! You’re on Rails!”가 보이는데 첫 페이지를 아이디어 페이지가 보이도록 바꾸겠습니다.

config/routes.rb 파일을 수정합니다. 첫번째 줄에 아래와 같이 추가합니다.

root to: redirect('/ideas')

브라우저에서 루트 패스(http://localhost:3000/ 또는 미리보기 주소)를 열어서 수정한 내용을 확인합니다.

Coach: 라우트를 설명합니다. 스태틱 파일의 관계와 라우트 순서를 포함하여 설명합니다.

Create static page in your app

애플리케이션를 만든 사람을 소개하는 정보를 담은 스태틱 페이지를 만들겠습니다!

rails generate controller pages info

위의 명령어 실행결과 app/views 폴더 아래에 pages 폴더와 그 아래에 소개 정보를 넣을 info.html.erb 파일을 생성합니다.

그리고 routes.rb 파일에 아래와 같이 추가됩니다.

get "pages/info"

app/views/pages/info.html.erb 파일에 HTML로 여러분에 대해 정보를 넣습니다. 새로 만든 페이지를 보려면, http://localhost:3000/pages/info 또는 클라우드 서비스 사용자의 경 미리보기 주소에 ‘/pages/info’ 붙여서 브라우저로 이동합니다.

6+.What next?

Additional Guides