Railsのnamespaceとscopeの違いとは?初心者にもわかるルーティングの書き方
生徒
「Railsのルーティングで、namespaceとscopeって見かけたんですが、どう違うんですか?」
先生
「良いところに気づきましたね。namespaceとscopeは、Railsでルート(URL)を整理するときによく使います。」
生徒
「どっちを使えばいいのか、迷っちゃいます…」
先生
「それじゃあ、初心者にもわかるように、それぞれの違いを順番に見ていこうか!」
1. Railsのルーティングとは?
Ruby on Rails(ルビーオンレイルズ)では、「ルーティング(routing)」という機能を使って、URLとコントローラの処理を結びつけます。たとえば「/users」というURLにアクセスしたときに、「UsersController」というクラスの処理が呼ばれる仕組みです。
ルーティングを書く場所は、プロジェクトの中の「config/routes.rb」というファイルです。
2. namespaceとは?
namespace(ネームスペース)は、管理画面やAPIのように機能をディレクトリで分けたいときによく使います。URLとコントローラのパス(場所)を両方まとめて整理できるのが特徴です。
例えば、「管理者用のユーザー管理画面」を作る場合、URLは/admin/users、コントローラはAdmin::UsersControllerにしたい、ということがあります。
このときは、以下のように書きます。
namespace :admin do
resources :users
end
この書き方をすると、以下のようなルーティングになります:
GET /admin/users → Admin::UsersController#index
GET /admin/users/:id → Admin::UsersController#show
つまり、namespaceを使うと「URLも、コントローラのパスも、自動でadminにまとめてくれる」ということです。
3. scopeとは?
scope(スコープ)は、namespaceに似ていますが、URLの指定とコントローラの場所を別々に設定したいときに使います。
例えば、URLには/adminを含めたいけど、コントローラは通常通りUsersControllerを使いたい場合です。
scope '/admin' do
resources :users
end
このように書くと、URLは以下のようになりますが、コントローラは通常のUsersControllerが使われます。
GET /admin/users → UsersController#index
つまりscopeを使うと、「URLだけ変えたいけど、コントローラは変えたくない」というときに便利です。
4. scope moduleとscope pathの使い分け
scopeはオプションを付けて、さらに細かく制御できます。
scope module
scope module:を使うと、「コントローラのモジュール名(パス)だけ」を指定できます。URLはそのままで、コントローラの場所だけを変えたいときに使います。
scope module: :admin do
resources :users
end
この書き方は、URLは/usersのままですが、コントローラはAdmin::UsersControllerになります。
GET /users → Admin::UsersController#index
scope path
scope path:を使うと、URLだけを変えて、コントローラの場所は変えずに使いたいときに使います。
scope path: '/admin' do
resources :users
end
この場合、URLは/admin/usersになりますが、コントローラはUsersControllerのままです。
GET /admin/users → UsersController#index
5. namespaceとscopeの違いを簡単にまとめる
| 種類 | URL | コントローラ | 用途 |
|---|---|---|---|
namespace |
変わる(例: /admin/users) | 変わる(例: Admin::UsersController) | URLとコントローラ両方まとめて分けたい |
scope '/admin' |
変わる(例: /admin/users) | 変わらない(UsersController) | URLだけ変えたい |
scope module: :admin |
変わらない(例: /users) | 変わる(Admin::UsersController) | コントローラだけ変えたい |
scope path: '/admin' |
変わる(例: /admin/users) | 変わらない(UsersController) | URLだけ変えたい |
このように、namespaceは全部まとめて変わるのに対して、scopeは部分的に変えることができるのが違いです。
6. どれを使えばいいの?初心者の目線で選び方を解説
どの書き方を使えばいいのか迷ったら、次のように考えると良いでしょう。
- 管理画面やAPI用に別のディレクトリ構成で作りたい →
namespace - URLだけ変えたい(表示上だけ) →
scope path - コントローラの場所だけ変えたい(URLはそのままで) →
scope module
Railsのルーティングでは、コードの読みやすさや将来のメンテナンスのしやすさを意識するのがとても大切です。
まとめ
namespaceとscopeを理解するとRailsルーティング設計が明確になる
この記事では、Railsのルーティング設計において重要な役割を持つnamespaceとscopeの違いについて、初心者の方にも分かりやすいように順を追って解説してきました。RailsではURLとコントローラの対応関係を明確にすることが非常に重要であり、その中心となるのがconfig/routes.rbに記述するルーティング定義です。
namespaceは、URLとコントローラの両方をまとめて整理したいときに使う書き方です。管理画面や管理者専用ページ、API用の機能など、「役割が明確に分かれた機能群」を作る際に非常に相性が良いのが特徴です。URLに/adminが付き、コントローラもAdmin::UsersControllerのようにディレクトリ構造が分かれるため、コード全体の見通しが良くなります。
一方でscopeは、URLとコントローラを柔軟に切り分けたい場合に活躍します。URLだけを変更したい場合はscope path、コントローラのモジュール構成だけを変えたい場合はscope moduleを使うことで、既存の構造を大きく変えずにルーティングを調整できます。この柔軟さがscopeの最大の強みと言えるでしょう。
特に初心者の方が混乱しやすいポイントは、「URLが変わるのか」「コントローラが変わるのか」という点です。namespaceはその両方が変わるのに対し、scopeはどちらか一方、または必要な部分だけを変更できます。この違いを理解しておくことで、ルーティング設計の意図がはっきりし、後からコードを見直したときにも迷いにくくなります。
Railsのルーティングは、単に動けば良いというものではなく、「人が見て分かりやすいか」「将来の拡張や修正がしやすいか」という視点がとても大切です。namespaceとscopeを正しく使い分けることで、URL設計とディレクトリ構成が自然に揃い、Railsらしい読みやすいアプリケーション構造を作ることができます。
まとめとしてのサンプルルーティング
ここで、今回学んだnamespaceとscopeの考え方を一つの例にまとめて確認してみましょう。管理画面と通常画面を分けつつ、役割ごとにルーティングを整理しています。
# routes.rb
# 管理画面用(URLもコントローラも分ける)
namespace :admin do
resources :users
end
# URLだけ管理用にしたい場合
scope path: '/admin' do
resources :reports
end
# コントローラだけ管理用に分けたい場合
scope module: :admin do
resources :settings
end
GET /admin/users → Admin::UsersController#index
GET /admin/reports → ReportsController#index
GET /settings → Admin::SettingsController#index
このように、namespaceとscopeを使い分けることで、URL構造とコントローラ構成を目的に応じて整理できます。どの書き方が正解というわけではなく、「何を分けたいのか」を考えることが大切です。
生徒
「namespaceとscopeの違いが、やっと整理できました。どこが変わるのかを意識すれば迷わないですね。」
先生
「その通りです。URLとコントローラのどちらを分けたいのかを考えるのがポイントですね。」
生徒
「管理画面はnamespace、見た目のURLだけ変えたいならscope、という考え方が分かりやすかったです。」
先生
「良い理解です。Railsのルーティングは設計の土台になるので、ここをしっかり押さえると後が楽になりますよ。」
生徒
「これからは、routes.rbを書くときに、将来の構成も意識してnamespaceとscopeを選びます。」