SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

Railsによるクライアントサイド開発入門

Rails 7ではReactアプリ作成が簡単に! importmap-railsとPropshaftを活用したチュートリアルで体感しよう

Railsによるクライアントサイド開発入門 第2回

  • X ポスト
  • このエントリーをはてなブックマークに追加

 本連載では、2021年12月にリリースされたRuby on Rails 7にフォーカスし、クライアントサイド開発のためのさまざまな機能を、API開発やリアルタイムWeb開発も絡めながら紹介していきます。連載第2回となる今回は、Rails 7で導入された新機能から、importmap-railsとPropshaftを使ってReactアプリを開発する過程を通じ、これらのライブラリの目的と機能について理解します。

  • X ポスト
  • このエントリーをはてなブックマークに追加

はじめに

 WebアプリケーションフレームワークのRuby on Railsは、2021年12月にバージョン7となりました。これに伴い、クライアントサイド開発のサポートについても大きな変化を遂げ、多様な選択肢が提供されるようになりました。本連載では、このRails 7にフォーカスし、クライアントサイド開発のためのさまざまな機能を、API開発やリアルタイムWeb開発も絡めながら紹介していきます。

対象読者

  • Ruby on Railsを長らく使ってきた方
  • 他のWebアプリケーション開発フレームワークを使ってきた方
  • Railsにおけるフロントエンド開発に関心のある方

必要な環境

 本記事のサンプルコードは、以下の環境で動作を確認しています。

  • macOS Monterey
    • Ruby 3.1.0p0
    • Ruby on Rails 7.0.2.3
    • Google Chrome 100

フロントエンド開発関連のrails newコマンドのオプション

 最初に、Rails 7のrails newコマンドで指定可能な、フロントエンド開発関連のオプションをまとめておきます。オプションをあらかじめ確認しておくことで、どのようにライブラリの選択ができるかを把握できます。また、オプションを適切に指定することで、アプリケーション作成のタイミングで構成を決定できます。

 Railsアプリケーションを構成するライブラリは多岐にわたり、複雑に連携していますから、あとから構成を変更するのはかなり面倒です。できれば、アプリケーション作成時にライブラリを選択しておいた方がよいでしょう。以下の表は、フロントエンド開発関連のオプションのみをまとめたものです。

表 rails newコマンドのフロントエンド開発関連のオプション
オプション 概要 デフォルト
-A、--skip-asset-pipeline アセットパイプラインを使用しない 使用する
-a、--asset-pipeline=ASSET_PIPELINE アセットパイプラインの指定(sprockets、propshaft) sprockets
-J、--skip-javascript JavaScriptファイルを組み込まない 組み込む
--skip-hotwire Hotwireを組み込まない 組み込む
-j、--javascript=JAVASCRIPT JavaScriptアプローチの選択(importmap、webpack、esbuild、rollup) importmap
-c、--css=CSS CSSプロセッサの選択(tailwind、bootstrap、bulma、postcss、sass) なし

 一部のオプションは、--no-skip-asset-pipelineのように「no-」をプレフィクスとして付加することでオプションを無効にできますが、単独で使用することはないので表では省略しています。

[NOTE]Hotwire

 Hotwireは、SPA(Single Page Application)ライクなアプリケーション開発をサポートするフレームワークです。turbo-railsとstimulus-railsという2つのライブラリで構成されます。JavaScriptのコードをほとんど記述することなく、Ajaxによるフォーム処理などが可能です。HotwireによるAjax処理ひいてはSPAライクな動作については後続の回で紹介する予定です。

次のページ
Rails 7ではより容易に! Reactアプリを作成してみよう!

この記事は参考になりましたか?

  • X ポスト
  • このエントリーをはてなブックマークに追加
Railsによるクライアントサイド開発入門連載記事一覧

もっと読む

この記事の著者

WINGSプロジェクト 山内 直(WINGSプロジェクト ヤマウチ ナオ)

WINGSプロジェクトについて> 有限会社 WINGSプロジェクトが運営する、テクニカル執筆コミュニティ(代表 山田祥寛)。主にWeb開発分野の書籍/記事執筆、翻訳、講演等を幅広く手がける。2018年11月時点での登録メンバは55名で、現在も執筆メンバを募集中。興味のある方は、どしどし応募頂きたい。著書記事多数。 RSS Twitter: @yyamada(公式)、@yyamada/wings(メンバーリスト) Facebook <個人紹介> WINGSプロジェクト所属のテクニカルライター。出版社を経てフリーランスとして独立。ライター、エディター、デベロッパー、講師業に従事。屋号は「たまデジ。」。

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

山田 祥寛(ヤマダ ヨシヒロ)

静岡県榛原町生まれ。一橋大学経済学部卒業後、NECにてシステム企画業務に携わるが、2003年4月に念願かなってフリーライターに転身。Microsoft MVP for Visual Studio and Development Technologies。執筆コミュニティ「WINGSプロジェクト」代表。主な著書に「独習シリーズ(Java・C#・Python・PHP・Ruby・JSP&サーブレットなど)」「速習シリーズ(ASP.NET Core・Vue.js・React・TypeScript・ECMAScript、Laravelなど)」「改訂3版JavaScript本格入門」「これからはじめるReact実践入門」「はじめてのAndroidアプリ開発 Kotlin編 」他、著書多数

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事は参考になりましたか?

この記事をシェア

  • X ポスト
  • このエントリーをはてなブックマークに追加
CodeZine(コードジン)
https://codezine.jp/article/detail/15973 2022/06/27 11:00

おすすめ

アクセスランキング

アクセスランキング

イベント

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

アクセスランキング

アクセスランキング