SHOEISHA iD

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

連載記事

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

CodeZine BOOKS(コードジン・ブックス)は、CodeZineの連載からカットアップした、開発現場の課題解決に役立つ書籍シリーズです。

書籍に関する記事を見る

'); googletag.cmd.push(function() { googletag.pubads().addEventListener('slotRenderEnded', function(e) { var ad_id = e.slot.getSlotElementId(); if (ad_id == 'div-gpt-ad-1659428980688-0') { var ad = $('#'+ad_id).find('iframe'); if ($(ad).width() == 728) { var ww = $(window).width(); ww = ww*0.90; var style = document.createElement("style"); document.head.appendChild( style ); var sheet = style.sheet; sheet.insertRule( "#div-gpt-ad-1659428980688-0 iframe {-moz-transform: scale("+ww/728+","+ww/728+");-moz-transform-origin: 0 0;-webkit-transform: scale("+ww/728+","+ww/728+");-webkit-transform-origin: 0 0;-o-transform: scale("+ww/728+","+ww/728+");-o-transform-origin: 0 0;-ms-transform: scale("+ww/728+","+ww/728+");-ms-transform-origin: 0 0;}", 0 ); sheet.insertRule( "#div-gpt-ad-1659428980688-0 div{ height:"+(90*ww/728)+"px;width:"+728+"px;}", 0 ); } else { if ($(window).width() < 340) { var ww = $(window).width(); ww = ww*0.875; var style = document.createElement("style"); document.head.appendChild( style ); var sheet = style.sheet; sheet.insertRule( "#div-gpt-ad-1659428980688-0 iframe {-moz-transform: scale("+ww/320+","+ww/320+");-moz-transform-origin: 0 0;-webkit-transform: scale("+ww/320+","+ww/320+");-webkit-transform-origin: 0 0;-o-transform: scale("+ww/320+","+ww/320+");-o-transform-origin: 0 0;-ms-transform: scale("+ww/320+","+ww/320+");-ms-transform-origin: 0 0;}", 0 ); sheet.insertRule( "#div-gpt-ad-1659428980688-0 div{ height:"+(180*ww/320)+"px;width:"+320+"px;}", 0 ); } } } }); }); } else { document.write('
'); document.write('
'); }
Flutterで始めるモバイルアプリ開発

Flutterとは何か? 使うメリットや特徴を理解する

Flutterで始めるモバイルアプリ開発 第1回

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

 2018年12月、Googleは「Flutter」というモバイルアプリ用のフレームワークをリリースしました。さまざまなモバイルフレームワークがある中で、改めてGoogleがリリースしたFlutterとはどのようなもので、どういった利点や特徴があるのでしょうか。まだ知らないという方や聞いたことはあるがよく分からないという方も多いと思います。今回は、筆者の経験や感想などを踏まえて、Flutterについて紹介していきます。

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

はじめに

 Flutterは、「モバイルアプリフレームワーク」という位置付けで紹介されることが多くなっています。「モバイルアプリフレームワーク」とは、「モバイル」つまり、AndroidとiOSを同じソースを共有して、同時に作成することができるもの。もちろん、厳密には100%同じソースとは言い切れない場合もあります。そこで、もう少し広義の意味では同じ言語でiOS/Androidのアプリ開発ができる場合であれば「モバイルフレームワーク」と呼ぶ場合もあります。

対象

 筆者の主観が含まれてしまいますが、特にFlutterをおすすめしたい人は以下のような開発者です。

  • モバイルアプリ開発をこれから本格的に始めたいWebアプリ開発者
  • Androidアプリ開発者だが、iOSの開発も始めたい開発者
  • React Nativeがなじめないと思っている開発者
  • Apache Cordovaを卒業したいアプリ開発者

 特に、上記に当てはまる方にはなじみやすいソリューションであり、もちろんそれ以外の方でも十分利用する価値があるフレームワークです。

Dartという言語

 Flutterは、「Dart」という言語を使って開発をしていきます。多くの方にとって、少々聞き慣れない言語かもしれません。AndroidやiOSのためにJavaやSwiftなど別の新しい言語を覚えるのが大変なので、モバイルフレームワークを探している方にとっては良い印象を持ちづらいでしょう。できればすでに知っている言語でモバイルアプリ開発ができれば良いなと思っているところに、水を差されたような気持ちになった方もいるかもしれません。しかし、JavaScriptやJavaを知っている方であれば、Dartについてそれほど構える必要はありません。

これまで注目されてこなかったDart言語

 もともと「Dart」は、JavaScriptの代替言語として2011年にリリースされました。そのため、TypeScriptと似ており、目的も同じのためおおよそ同等レベルの言語と捉えても良いです。また、Flutterを使ったモバイルアプリを作るために、Dartについて勉強していなくても大丈夫です。

Dart言語のメリット

 TypeScriptは多くのソリューションにとって、バグなどが発生しにくいJavaScriptを書くための変換ツールにすぎません。筆者も以前はTypeScriptを使っていましたが、今では使わなくなってきました。その理由としては、TypeScriptで生成されたJavaScriptでの問題点を調査するということが発生するようになってきたからです。TypeScript自体の問題ではないのですが、TypeScriptを知っているけどJavaScriptを知らない開発者がいる状況が増えるなど、そういった問題が出てきたように思えます。

 こういった中間ソリューションは、問題にぶつかったとき、その環境のネイティブ言語を扱っている場合に比べて問題が複雑になるため、解決方法が難しくなるケースがあります。そして、問題が解決できるくらいの知識がつくと、中間ソリューションがいらないほど、熟知してしまったということになります。

 Dart言語も、TypeScriptのようにJavaScriptに変換するためのAltJSという利用方法もありますが、むしろ以下のようなメリットがあります。

  • UIをブロックしない非同期処理や、UI定義もしやすいコレクション記述などUI処理を記述しやすい言語
  • 開発しながら同時に動作を確認できるような生産性を考慮した開発環境
  • AOTコンパイラによる幅広いプラットフォームにネイティブ対応が可能で、スマホ以外の利用も考慮

 そして、DartはこのFlutterというモバイルフレームワークにとってはネイティブの言語であり、その利点がさまざまなところで生かされています。

モバイルアプリ開発の課題

 Flutterの特徴や利点について紹介する前に、「モバイルアプリ開発」について説明しましょう。モバイルアプリについて開発したことがある方ならすでに知っているかもしれませんが、実際にWebアプリを作ったことはあるけどモバイルアプリはまだ無いという方も多数いると思います。

 そのような方にとっては、いざモバイルフレームワークを採用して使って見ると、最初に重要と思っていた部分以外が実は重要であることに気がつくことでしょう。AndroidやiOS用のアプリを実際作ろうとすると、以下のようなさまざまな違いによる問題にぶつかります。

  • 開発言語の違い
  • 開発環境・ビルド環境の違い(iOSのアプリはMacでないと開発できないなど)
  • APIの違い(端末のセキュリティや制約・方向性の違い)
  • UIの違い(操作方法の違い)

 モバイルフレームワークを選ぶ際に多くの方は、「開発言語の違い」に関心を持ちます。しかし、実際に開発を進めていけば「開発言語」の問題はそれ以外の問題に比べて大きくないことが分かります。特に、Macを使わない場合には、iOSの開発環境の違いなどを理解することが難しく、APIの違いも単に実装の違いから生じるものから、セキュリティや制約・方向性の違いがあります。

 例えば、アプリがバックエンドになった場合に、Androidの場合では処理が動作していたのに、iOSでは処理が止まっていたということが発生します。また、プッシュ通知などではWiFi接続しているとiOSでは受信できるのに、Androidでは受信できないほか、iOSとAndroidでサポートされている画像や動画フォーマットの違いなど実際に使ってみないと気づきにくい部分もあります。

 できることが同じであれば、APIの違いがあってもフレームワークが吸収してくれる場合もあります。しかし、各OSが持つセキュリティ制約などはフレームワークは吸収することはできません。また、内部で利用しているライブラリが違うために、異なる挙動になってしまうというケースもあります。もちろんフレームワーク側でできるだけ吸収しようとしますが、すべて対応しきれないのが現状です。実はこのように「言語の違い」以外にも、モバイルフレームワークがどの程度これらの違いを吸収できるのかも、大きな指標の1つです。

会員登録無料すると、続きをお読みいただけます

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

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

メールバックナンバー

次のページ
さまざまなモバイルフレームワークの特徴

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

  • X ポスト
  • このエントリーをはてなブックマークに追加
Flutterで始めるモバイルアプリ開発連載記事一覧

もっと読む

この記事の著者

WINGSプロジェクト 小林 昌弘(コバヤシ マサヒロ)

<WINGSプロジェクトについて>有限会社 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/12718 2020/09/02 11:00
" ); }

おすすめ

アクセスランキング

  1. 1
    管理職の24.1%、今後管理職を「続けたくない」と回答。理由は「責任やストレス」が最多に NEW
  2. 2
    フロントエンドの定番ライブラリ「React」バージョン19の新機能を紹介──アクションによる非同期処理の進化
  3. 3
    IPA、DXの先進事例を素早く効率的に検索できるWebサイト「デジタル事例データベース」を公開
  4. 4
    ランサーズ、「2024年必要とされたスキルランキング」を公開。「Lancers」上のデータを集計
  5. 5
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  1. 6
    Apple、2024 App Store Awardsの受賞者発表 NEW
  2. 7
    Python初心者向けチュートリアル「Python Boot Camp in 鹿児島 3rd」、2025年1月11日に開催 NEW
  3. 8
    「CentOS Stream 10」発表、Linuxカーネル 6.12 LTSを搭載
  4. 9
    「CUDA」 ~マンガでプログラミング用語解説
  5. 10
    楽天、日本語に最適化したAIモデル「Rakuten AI 2.0」と「Rakuten AI 2.0 mini」を発表 NEW

アクセスランキング

  1. 1
    管理職の24.1%、今後管理職を「続けたくない」と回答。理由は「責任やストレス」が最多に NEW
  2. 2
    フロントエンドの定番ライブラリ「React」バージョン19の新機能を紹介──アクションによる非同期処理の進化
  3. 3
    IPA、DXの先進事例を素早く効率的に検索できるWebサイト「デジタル事例データベース」を公開
  4. 4
    ランサーズ、「2024年必要とされたスキルランキング」を公開。「Lancers」上のデータを集計
  5. 5
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  6. 6
    Apple、2024 App Store Awardsの受賞者発表 NEW
  7. 7
    Python初心者向けチュートリアル「Python Boot Camp in 鹿児島 3rd」、2025年1月11日に開催 NEW
  8. 8
    「CentOS Stream 10」発表、Linuxカーネル 6.12 LTSを搭載
  9. 9
    「CUDA」 ~マンガでプログラミング用語解説
  10. 10
    楽天、日本語に最適化したAIモデル「Rakuten AI 2.0」と「Rakuten AI 2.0 mini」を発表 NEW
  1. 1
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  2. 2
    「CUDA」 ~マンガでプログラミング用語解説
  3. 3
    ITエンジニア本大賞2025、投票締切直前! みんなで選んだ歴代の大賞本を振り返って一挙紹介
  4. 4
    デスクトップアプリを開発しよう! 「Rust」と「Tauri 2.0」の基本情報と環境整備の仕方を解説
  5. 5
    今後生成AIとどう向き合うべきなのか? 現場のエンジニアと研究者が最新研究事例から語り合う
  6. 6
    2024年12月に開催される注目のITエンジニア向けカンファレンス5選
  7. 7
    日本在住の英語を話すソフトウェア開発者、年収の中央値は950万円に
  8. 8
    Vue.js3.4~3.5の新機能をまとめて紹介! 新しいAPIやSSRの改善
  9. 9
    VSCodeをドキュメント作成に活用――テキストエディタ、Markdownエディタの設定と拡張機能を解説
  10. 10
    2024年の提示年収が高いプログラミング言語は? paiza調査によるランキングが発表

イベント

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

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

メールバックナンバー

アクセスランキング

  1. 1
    管理職の24.1%、今後管理職を「続けたくない」と回答。理由は「責任やストレス」が最多に NEW
  2. 2
    フロントエンドの定番ライブラリ「React」バージョン19の新機能を紹介──アクションによる非同期処理の進化
  3. 3
    IPA、DXの先進事例を素早く効率的に検索できるWebサイト「デジタル事例データベース」を公開
  4. 4
    ランサーズ、「2024年必要とされたスキルランキング」を公開。「Lancers」上のデータを集計
  5. 5
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  1. 6
    Apple、2024 App Store Awardsの受賞者発表 NEW
  2. 7
    Python初心者向けチュートリアル「Python Boot Camp in 鹿児島 3rd」、2025年1月11日に開催 NEW
  3. 8
    「CentOS Stream 10」発表、Linuxカーネル 6.12 LTSを搭載
  4. 9
    「CUDA」 ~マンガでプログラミング用語解説
  5. 10
    楽天、日本語に最適化したAIモデル「Rakuten AI 2.0」と「Rakuten AI 2.0 mini」を発表 NEW

アクセスランキング

  1. 1
    管理職の24.1%、今後管理職を「続けたくない」と回答。理由は「責任やストレス」が最多に NEW
  2. 2
    フロントエンドの定番ライブラリ「React」バージョン19の新機能を紹介──アクションによる非同期処理の進化
  3. 3
    IPA、DXの先進事例を素早く効率的に検索できるWebサイト「デジタル事例データベース」を公開
  4. 4
    ランサーズ、「2024年必要とされたスキルランキング」を公開。「Lancers」上のデータを集計
  5. 5
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  6. 6
    Apple、2024 App Store Awardsの受賞者発表 NEW
  7. 7
    Python初心者向けチュートリアル「Python Boot Camp in 鹿児島 3rd」、2025年1月11日に開催 NEW
  8. 8
    「CentOS Stream 10」発表、Linuxカーネル 6.12 LTSを搭載
  9. 9
    「CUDA」 ~マンガでプログラミング用語解説
  10. 10
    楽天、日本語に最適化したAIモデル「Rakuten AI 2.0」と「Rakuten AI 2.0 mini」を発表 NEW
  1. 1
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  2. 2
    「CUDA」 ~マンガでプログラミング用語解説
  3. 3
    ITエンジニア本大賞2025、投票締切直前! みんなで選んだ歴代の大賞本を振り返って一挙紹介
  4. 4
    デスクトップアプリを開発しよう! 「Rust」と「Tauri 2.0」の基本情報と環境整備の仕方を解説
  5. 5
    今後生成AIとどう向き合うべきなのか? 現場のエンジニアと研究者が最新研究事例から語り合う
  6. 6
    2024年12月に開催される注目のITエンジニア向けカンファレンス5選
  7. 7
    日本在住の英語を話すソフトウェア開発者、年収の中央値は950万円に
  8. 8
    Vue.js3.4~3.5の新機能をまとめて紹介! 新しいAPIやSSRの改善
  9. 9
    VSCodeをドキュメント作成に活用――テキストエディタ、Markdownエディタの設定と拡張機能を解説
  10. 10
    2024年の提示年収が高いプログラミング言語は? paiza調査によるランキングが発表