【Flutter】get_itを使ってお気に入り機能を作ってみた!

image

今回の成果物

今回の開発環境について紹介

開発環境

  • VSCode 1.73.1
  • Flutter 3.13.9
  • Dart 3.1.5

get_itとは

get_it は Dart のサービスロケーターのパッケージです。

Flutter が 1.0 になった 2018 年 12 月より半年以上前から存在しているみたい。。。

何ができるの?

get_it パッケージは、依存性の管理に使用されるパッケージです。

依存関係を登録し、アプリケーション内で再利用するためのクラスのインスタンスを提供します。

  • アプリ内でよく使う機能などを1箇所で管理ができる!

  • どのページからでも使用することができる!

つまり

再利用(よく使用)するものを1箇所にまとめて使い回しすることができる

作ってみよう

今回は実際にお気に入り機能を作成していきます。

今回はlocator.dartというファイルを準備しそこに記述していきました。

こちらがlocator.dartの全体です。

GetIt locator = GetIt.instance;

void setupLocator() {
  locator.registerSingleton(UserService());
}

class UserService {
  final favoriteItemList = <int>[];

  void addFavoriteItem({required int listNumber}) {
    favoriteItemList.add(listNumber);
  }
  void removeFavoriteItem({required int listNumber}) {
    favoriteItemList.remove(listNumber);
  }
  Future<bool> isFavorite({
    required int listNumber,
  }) async {
    var isFavorite = false;
    for (final favoriteItem in favoriteItemList) {
      if (favoriteItem == listNumber) {
        isFavorite = true;
      }
    }
    return isFavorite;
  }
}

こちらで記述したUserServiceの機能がどこでも呼び出すことができるようになりました。

実際に呼び出して使用方法までみていきましょう!

//ここで呼び出しする
final UserService userService = locator<UserService>();

IconButton(
    onPressed: () async {
        //呼び出し
        final isFavorite = await userService.isFavorite(listNumber: index);
        setState(() {
            isFavorite
                //呼び出し
                ? userService.removeFavoriteItem(listNumber: index)
                //呼び出し
                : userService.addFavoriteItem(listNumber: index);
        });
    },
    icon: FutureBuilder(
        future: future(listNumber: index),
        builder: (context, snapshot) {
            final isFavorite = snapshot.data;
            if (isFavorite != null) {
                return Icon(isFavorite ? Icons.star : Icons.star_border);
            }
            return const SizedBox();
        },
    ),
)

呼び出しをすることでそのページ内で利用することができる!

まとめ

かなりシンプルなコードでデータ管理ができましたね!

これを別ページでも呼び出すことができるのが魅力の一つかと思います

ちょっとした機能の実装に最適かも

参考にしたもの

解説がとてもわかりやすい

(今回のget_itとはの部分はこちらの内容から来ています。)

解説と簡単な使用例が載っていたのでこちらを参考にしました

(本記事のコード作成法はこのサイトを参考にしています。)

お知らせ

Flutterで実現する 従来の約6割のコストで高品質なアプリ開発

Flutterで実現する 従来の約6割のコストで高品質なアプリ開発

岐阜を拠点に、全国にも対応。可茂IT塾のアプリ開発サービス。Flutterによるクロスプラットフォーム開発で通常の6割のコストを実現。

Read More
可茂IT塾ではFlutter/Reactのインターンを募集しています!

可茂IT塾ではFlutter/Reactのインターンを募集しています!

可茂IT塾ではFlutter/Reactのインターンを募集しています!一定以上のスキルをを習得した方には有給でのインターンも受け入れています。

Read More
可茂IT塾開校!

可茂IT塾開校!

2020年1月から可茂IT塾がはじまります!可茂IT塾は美濃加茂市のコワーキングスペース「こやぁね」を拠点として、プログラミングやデザインなどの様々な講座を開催していく予定です。

Read More

タグ

Flutter (127)初心者向け (32)イベント (20)Google Apps Script (17)可茂IT塾 (13)Nextjs (13)AI (9)React (8)riverpod (7)デザイン (7)Firebase (7)Figma (6)VSCode (6)JavaScript (6)ChatGPT (5)Slack (5)TypeScript (5)新卒 (4)就活 (4)Prisma (4)Dart (4)アプリ開発 (4)お知らせ (4)FlutterWeb (3)経験談 (3)NestJS (3)tailwindcss (3)ワーケーション (3)インターン (3)Web (2)Obsidian (2)Supabase (2)設計 (2)線型計画法 (2)事例 (2)Git (2)CSS (2)Freezed (2)Image (2)File (2)GitHub Actions (2)Material Design (2) (2)会社員 (2)画像 (2)Mac (2)iOS (2)React Hooks (2)社会人 (2)大学生 (2)RSS (1)Google (1)CodeRunner (1)vibe-kanban (1)NotebookLM (1)個人開発 (1)SVG (1)Android (1)Unity (1)WebView (1)Twitter (1)フルリモート (1)TextScaler (1)textScaleFactor (1)学生向け (1)Java (1)Spring Boot (1)shell script (1)正規表現 (1)table (1)テーブル (1)hooks (1)パワーポイント (1)ブックマーク (1)Pocket (1)ブクマク (1)MCPサーバー (1)OpenAI (1)ベクトル検索 (1)趣味 (1)モンスターボール (1)SCSS (1)Swift (1)MapBox (1)Cupertino (1)gpt-oss (1)生成AI (1)llama.cpp (1)LLM (1)ListView (1)postgresql (1)cloudrun (1)gcp (1)就活浪人 (1)既卒 (1)保守性 (1)iPad (1)シェアハウス (1)スクレイピング (1)PageView (1)画面遷移 (1)dotenvx (1)dotenv (1)Python (1)flutter_hooks (1)Gmail (1)GoogleWorkspace (1)ShaderMask (1)google map (1)Google Places API (1)GCPコンソール (1)Google_ML_Kit (1)Vercel (1)Google Domains (1)DeepLeaning (1)深層学習 (1)Google Colab (1)Google Chat Bot (1)Firebase Analytics (1)Gemini AI (1)コード生成 (1)GitHub Copilot (1)gemini (1)オンラインオフィス (1)html (1)オブジェクト指向 (1)クラスの継承 (1)ポリモーフィズム (1)LINE Messaging API (1)LINE Notify (1)LINE (1)Bitcoin (1)bitFlyer (1)コミュニティー (1)文系エンジニア (1)build_runner (1)ヒーター (1)作業効率 (1) (1)Flutter実践開発 (1)permission_handler (1)flutter_local_notifications (1)markdown (1)GlobalKey (1)ValueKey (1)Key (1)アイコン (1)go_router (1)FireStorage (1)debug (1)datetime_picker (1)Apple Store Connect (1)FlutterGen (1)デバッグ (1)Widget Inspector (1)VRChat (1)API (1)検索機能 (1)ローディング (1)Skeletonizer (1)Simmer (1)Shader (1)FFI (1)Rust (1)SharedPreferences (1)オフラインサポート (1)Navigator (1)メール送信 (1)FlutterFlow (1)Firebase App Distribution (1)Fastlane (1)Dio (1)CustomClipper (1)ClipPath (1)video_player (1)IMA (1)カスタム認証 (1)英語 (1)学習 (1)ポッドキャスト (1)アニメーション (1)Arduino (1)ESP32 (1)フリーランス (1)会社設立 (1)csv (1)docker (1)GithubActions (1)Dialog (1)BI (1)トラブルシューティング (1)エディタ (1)Cursor (1)sora2 (1)iPhone (1)Gemini CLI (1)Claude Code (1)LifeHack (1)ショートカット (1)Chrome (1)高校生 (1)キャリア教育 (1)非同期処理 (1)生体認証 (1)BackdropFilter (1)レビュー (1)Antigravity (1)getAuth (1)クローズドテスト (1)PlayConsole (1)Algolia (1)コンサルティング (1)Symbol (1)

お知らせ

Flutterで実現する 従来の約6割のコストで高品質なアプリ開発

Flutterで実現する 従来の約6割のコストで高品質なアプリ開発

岐阜を拠点に、全国にも対応。可茂IT塾のアプリ開発サービス。Flutterによるクロスプラットフォーム開発で通常の6割のコストを実現。

Read More
可茂IT塾ではFlutter/Reactのインターンを募集しています!

可茂IT塾ではFlutter/Reactのインターンを募集しています!

可茂IT塾ではFlutter/Reactのインターンを募集しています!一定以上のスキルをを習得した方には有給でのインターンも受け入れています。

Read More
可茂IT塾開校!

可茂IT塾開校!

2020年1月から可茂IT塾がはじまります!可茂IT塾は美濃加茂市のコワーキングスペース「こやぁね」を拠点として、プログラミングやデザインなどの様々な講座を開催していく予定です。

Read More