Flutter数据共享插件bdaya_shared_value的使用

Flutter数据共享插件bdaya_shared_value的使用

bdaya_shared_value 是一个用于在Flutter应用中管理全局状态的插件。它基于 InheritedModel 实现,提供了一种低冗余的状态管理解决方案。以下是如何使用该插件的详细说明和示例代码。

1. 初始化

首先,需要声明一个 SharedValue 变量,并将其初始化为一个具体的值。重要的是,这个变量应声明为 final,以防止意外覆盖。

import 'package:bdaya_shared_value/bdaya_shared_value.dart';

// This global SharedValue can be shared across the entire app
// IMPORTANT: Variable declared as final
final SharedValue<int> counter = SharedValue(
  // initial value
  value: 0,
  // disk storage key for shared_preferences (optional)
  key: "counter",
  // autosave to shared prefs when value changes (optional)
  autosave: true,
);

void main() {
  runApp(
    // Don't forget this bit of initialization code!
    SharedValue.wrapApp(
      MyApp(),
    ),
  );
}

2. 使用

SharedValue 允许你在没有 BuildContext 的情况下进行读取和更新操作。这使得它在某些场景下比其他状态管理方案更为便捷。

读取和更新

void main() {
  // Read [counter]
  print(counter.$);

  // Update [counter]
  counter.$ += 1;
}

Widget build(BuildContext context) {
  // The .of(context) bit makes this widget rebuild automatically
  int counterValue = counter.of(context);

  return Text("Counter: $counterValue");
}

持久化存储

你可以通过 load()store() 方法将数据保存到 shared_preferences 中:

void main() async {
  // Load [counter]'s value from shared preferences
  await counter.load();

  // Store [counter]'s value to shared preferences (enabling `autosave` does this automatically)
  await counter.store();
}

3. 完整示例

以下是一个完整的示例应用,展示了如何使用 bdaya_shared_value 进行状态管理和持久化存储。

import 'dart:async';
import 'package:bdaya_shared_value/bdaya_shared_value.dart';
import 'package:flutter/material.dart';

// This global SharedValue can be shared across the entire app
final SharedValue<int> counter = SharedValue(
  value: 0, // initial value
  key: "counter", // disk storage key for shared_preferences
  autosave: true, // autosave to shared prefs when value changes
);

final SharedValue<Duration> randomValue = SharedValue(value: Duration.zero);

void main() {
  WidgetsFlutterBinding.ensureInitialized();

  // load previous value from shared prefs
  counter.load();

  DateTime startedAt = DateTime.now();
  Timer.periodic(Duration(milliseconds: 50), (timer) {
    randomValue.$ = DateTime.now().difference(startedAt);
  });

  runApp(
    // don't forget this!
    SharedValue.wrapApp(
      MyApp(),
    ),
  );
}

class MyApp extends StatelessWidget {
  [@override](/user/override)
  Widget build(BuildContext context) {
    print("MyApp.build()");

    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: Scaffold(
        appBar: AppBar(
          title: Text("Shared value demo"),
        ),
        body: Center(
          child: Column(
            mainAxisAlignment: MainAxisAlignment.center,
            children: <Widget>[
              Text(
                'You have pushed the button this many times:',
              ),
              CounterText(),
              Padding(
                padding: const EdgeInsets.all(32),
                child: RandomText(),
              ),
            ],
          ),
        ),
        floatingActionButton: CounterButton(),
      ),
    );
  }
}

class CounterText extends StatelessWidget {
  [@override](/user/override)
  Widget build(BuildContext context) {
    // The .of(context) bit makes this widget rebuild automatically
    int counterValue = counter.of(context);

    print("CounterText.build() - $counterValue");

    return Text(
      '$counterValue',
      style: Theme.of(context).textTheme.headline4,
    );
  }
}

class CounterButton extends StatelessWidget {
  [@override](/user/override)
  Widget build(BuildContext context) {
    print("Button.build()");

    return FloatingActionButton(
      onPressed: _incrementCounter,
      tooltip: 'Increment',
      child: Icon(Icons.add),
    );
  }

  void _incrementCounter() {
    // update counter value and rebuild widgets
    counter.$ += 1;
  }
}

class RandomText extends StatelessWidget {
  [@override](/user/override)
  Widget build(BuildContext context) {
    return Text("Your time here: ${randomValue.of(context)}");
  }
}

更多关于Flutter数据共享插件bdaya_shared_value的使用的实战教程也可以访问 https://www.itying.com/category-92-b0.html

1 回复

更多关于Flutter数据共享插件bdaya_shared_value的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html


当然,以下是如何在Flutter项目中使用bdaya_shared_value插件进行数据共享的示例代码。这个插件允许你在Flutter应用中跨不同组件或页面共享数据。

1. 添加依赖

首先,你需要在pubspec.yaml文件中添加bdaya_shared_value依赖:

dependencies:
  flutter:
    sdk: flutter
  bdaya_shared_value: ^latest_version  # 请替换为最新版本号

然后运行flutter pub get来获取依赖。

2. 导入插件

在你需要使用数据共享的Dart文件中导入插件:

import 'package:bdaya_shared_value/bdaya_shared_value.dart';

3. 使用示例

以下是一个简单的示例,展示如何在两个页面中共享数据。

主页面 (main.dart)

import 'package:flutter/material.dart';
import 'package:bdaya_shared_value/bdaya_shared_value.dart';
import 'second_page.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(
          title: Text('Shared Value Example'),
        ),
        body: Center(
          child: Column(
            mainAxisAlignment: MainAxisAlignment.center,
            children: <Widget>[
              TextFormField(
                decoration: InputDecoration(labelText: 'Enter some text'),
                onChanged: (value) {
                  // 更新共享值
                  BdayaSharedValue.setString('sharedText', value);
                },
              ),
              SizedBox(height: 20),
              ElevatedButton(
                onPressed: () {
                  Navigator.push(
                    context,
                    MaterialPageRoute(builder: (context) => SecondPage()),
                  );
                },
                child: Text('Go to Second Page'),
              ),
            ],
          ),
        ),
      ),
    );
  }
}

第二页面 (second_page.dart)

import 'package:flutter/material.dart';
import 'package:bdaya_shared_value/bdaya_shared_value.dart';

class SecondPage extends StatefulWidget {
  @override
  _SecondPageState createState() => _SecondPageState();
}

class _SecondPageState extends State<SecondPage> {
  String? sharedText;

  @override
  void initState() {
    super.initState();
    // 获取共享值
    BdayaSharedValue.getString('sharedText').then((value) {
      setState(() {
        sharedText = value;
      });
    });
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Second Page'),
      ),
      body: Center(
        child: Text(sharedText ?? 'No shared value'),
      ),
    );
  }
}

解释

  1. 主页面:包含一个TextFormField,用于输入文本,并实时更新共享值。点击按钮后,导航到第二页面。
  2. 第二页面:在initState方法中,从BdayaSharedValue获取共享值,并在页面上显示。

通过这种方式,你可以在不同的页面或组件之间共享数据。bdaya_shared_value插件支持多种数据类型,如字符串、整数、布尔值等,具体使用方法可以参考插件的官方文档。

回到顶部