• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

Flutter GetX系列教程---Get Service

武飞扬头像
weixin_41779718
帮助2

安装

将 GetX 添加到你的 pubspec.yaml 文件中

dependencies:
   get: ^4.6.5

在需要用到的文件中导入,它将被使用。

import 'package:get/get.dart';

这个类就像一个 GetxController,它共享相同的生命周期onInit()、onReady()、onClose()。 但里面没有 “逻辑”。它只是通知GetX的依赖注入系统,这个子类不能从内存中删除。所以如果你需要在你的应用程序的生命周期内对一个类实例进行绝对的持久化,那么就可以使用GetxService。

main.dart

import 'package:flutter/material.dart';
import 'package:get/get.dart';
import 'GetxServiceW/Service.dart';
/// 初始化服务
Future<void> main() async {
  await initServices();
  runApp(MyApp());
}

Future<void> initServices() async {
  print("初始化服务");
  await Get.putAsync(() async => await Service());
  print("所有服务启动");
}


class MyApp extends StatelessWidget {

  @override
  Widget build(BuildContext context) {
    return GetMaterialApp(
      title: "Getx",
      home: GetXServiceExample(),
    );
  }
}

class GetXServiceExample extends StatelessWidget {
  const GetXServiceExample({Key? key}) : super(key: key);

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text("Getx Server"),
      ),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: [
            ElevatedButton(onPressed: (){
              print("点击了");
              Get.find<Service>().getCounter();
            }, child: Text("点击"))
          ],
        ),
      ),
    );
  }
}

学新通

Service.dart

import 'package:get/get.dart';
import 'package:shared_preferences/shared_preferences.dart';

class Service extends GetxService {

  Future<void> getCounter() async {
    // 数据持久化
    SharedPreferences prefs = await SharedPreferences.getInstance();
    // 读取持久化的值
    int count = (prefs.getInt("counter") ?? 0)   1;
    print("count 的值为: $count");
    // 把值设置到持久化中去
    await prefs.setInt("counter", count);
  }
}

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhgcaege
系列文章
更多 icon
同类精品
更多 icon
继续加载