Flutter本地数据存储插件app_preference_shared_preferences的使用

Flutter本地数据存储插件app_preference_shared_preferences的使用

简介

app_preference_shared_preferences 是一个基于 shared_preferences 的 Flutter 插件,用于在应用中实现简单的本地数据存储。它提供了对键值对数据的读写功能,并且可以轻松集成到现有的 Flutter 项目中。

以下是一个完整的示例,展示如何使用 app_preference_shared_preferences 插件来存储和读取本地数据。


安装插件

在项目的 pubspec.yaml 文件中添加依赖:

dependencies:
  app_preference_shared_preferences: ^1.0.0

然后运行以下命令以安装依赖:

flutter pub get

使用示例

1. 初始化插件

首先,确保在应用启动时初始化插件。通常可以在 main() 函数中完成:

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

void main() async {
  // 初始化插件
  await AppPreference.init();
  
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  [@override](/user/override)
  Widget build(BuildContext context) {
    return MaterialApp(
      home: HomeScreen(),
    );
  }
}

2. 存储数据

使用 AppPreference 类的静态方法来存储数据。例如,存储字符串、整数或布尔值:

// 存储字符串
await AppPreference.putString('username', 'JohnDoe');

// 存储整数
await AppPreference.putInt('age', 25);

// 存储布尔值
await AppPreference.putBool('isLoggedIn', true);

3. 读取数据

从本地存储中读取数据也非常简单:

// 读取字符串
String username = await AppPreference.getString('username');
print('Username: $username');

// 读取整数
int age = await AppPreference.getInt('age');
print('Age: $age');

// 读取布尔值
bool isLoggedIn = await AppPreference.getBool('isLoggedIn');
print('Is Logged In: $isLoggedIn');

4. 删除数据

如果需要删除某个键值对,可以使用 remove() 方法:

// 删除指定键值对
await AppPreference.remove('username');

// 清空所有数据
await AppPreference.clear();

完整示例代码

以下是一个完整的示例代码,展示了如何使用 app_preference_shared_preferences 插件进行本地数据存储和读取:

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

void main() async {
  // 初始化插件
  await AppPreference.init();

  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  [@override](/user/override)
  Widget build(BuildContext context) {
    return MaterialApp(
      home: HomeScreen(),
    );
  }
}

class HomeScreen extends StatefulWidget {
  [@override](/user/override)
  _HomeScreenState createState() => _HomeScreenState();
}

class _HomeScreenState extends State<HomeScreen> {
  String _username = '';
  int _age = 0;
  bool _isLoggedIn = false;

  [@override](/user/override)
  void initState() {
    super.initState();
    _loadData();
  }

  Future<void> _loadData() async {
    // 从本地存储中加载数据
    _username = await AppPreference.getString('username') ?? '';
    _age = await AppPreference.getInt('age') ?? 0;
    _isLoggedIn = await AppPreference.getBool('isLoggedIn') ?? false;

    setState(() {});
  }

  Future<void> _saveData() async {
    // 将数据保存到本地存储
    await AppPreference.putString('username', 'JohnDoe');
    await AppPreference.putInt('age', 25);
    await AppPreference.putBool('isLoggedIn', true);

    ScaffoldMessenger.of(context).showSnackBar(SnackBar(content: Text('Data saved')));
  }

  Future<void> _clearData() async {
    // 清除本地存储中的数据
    await AppPreference.clear();
    _loadData();
  }

  [@override](/user/override)
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('App Preference Example'),
      ),
      body: Padding(
        padding: const EdgeInsets.all(16.0),
        child: Column(
          children: [
            TextField(
              decoration: InputDecoration(hintText: 'Enter Username'),
              onChanged: (value) {
                setState(() {
                  _username = value;
                });
              },
            ),
            SizedBox(height: 16),
            TextField(
              keyboardType: TextInputType.number,
              decoration: InputDecoration(hintText: 'Enter Age'),
              onChanged: (value) {
                setState(() {
                  _age = int.tryParse(value) ?? 0;
                });
              },
            ),
            SizedBox(height: 16),
            ElevatedButton(
              onPressed: _saveData,
              child: Text('Save Data'),
            ),
            SizedBox(height: 16),
            ElevatedButton(
              onPressed: _clearData,
              child: Text('Clear Data'),
            ),
            SizedBox(height: 16),
            Text('Username: $_username'),
            Text('Age: $_age'),
            Text('Is Logged In: $_isLoggedIn ?'),
          ],
        ),
      ),
    );
  }
}

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

1 回复

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


app_preference_shared_preferences 是一个 Flutter 插件,用于在本地存储简单的键值对数据。它基于 Android 的 SharedPreferences 和 iOS 的 NSUserDefaults,提供了一种跨平台的本地数据存储解决方案。

以下是使用 shared_preferences 插件的基本步骤:

1. 添加依赖

首先,在 pubspec.yaml 文件中添加 shared_preferences 插件的依赖:

dependencies:
  flutter:
    sdk: flutter
  shared_preferences: ^2.0.6

然后运行 flutter pub get 来安装依赖。

2. 导入包

在需要使用 shared_preferences 的 Dart 文件中导入包:

import 'package:shared_preferences/shared_preferences.dart';

3. 使用 SharedPreferences

SharedPreferences 提供了多种方法来存储和读取数据。以下是一些常见的操作:

3.1 存储数据

Future<void> saveData() async {
  SharedPreferences prefs = await SharedPreferences.getInstance();
  
  // 存储字符串
  await prefs.setString('username', 'JohnDoe');
  
  // 存储整数
  await prefs.setInt('age', 25);
  
  // 存储布尔值
  await prefs.setBool('isLoggedIn', true);
  
  // 存储浮点数
  await prefs.setDouble('height', 5.9);
  
  // 存储字符串列表
  await prefs.setStringList('favoriteColors', ['Red', 'Green', 'Blue']);
}

3.2 读取数据

Future<void> readData() async {
  SharedPreferences prefs = await SharedPreferences.getInstance();
  
  // 读取字符串
  String? username = prefs.getString('username');
  print('Username: $username');
  
  // 读取整数
  int? age = prefs.getInt('age');
  print('Age: $age');
  
  // 读取布尔值
  bool? isLoggedIn = prefs.getBool('isLoggedIn');
  print('Is logged in: $isLoggedIn');
  
  // 读取浮点数
  double? height = prefs.getDouble('height');
  print('Height: $height');
  
  // 读取字符串列表
  List<String>? favoriteColors = prefs.getStringList('favoriteColors');
  print('Favorite Colors: $favoriteColors');
}

3.3 删除数据

Future<void> deleteData() async {
  SharedPreferences prefs = await SharedPreferences.getInstance();
  
  // 删除指定键的值
  await prefs.remove('username');
  
  // 清空所有数据
  await prefs.clear();
}

4. 示例代码

以下是一个完整的示例,展示了如何使用 shared_preferences 存储和读取数据:

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

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

class MyApp extends StatelessWidget {
  [@override](/user/override)
  Widget build(BuildContext context) {
    return MaterialApp(
      home: HomeScreen(),
    );
  }
}

class HomeScreen extends StatefulWidget {
  [@override](/user/override)
  _HomeScreenState createState() => _HomeScreenState();
}

class _HomeScreenState extends State<HomeScreen> {
  String? username;
  int? age;

  [@override](/user/override)
  void initState() {
    super.initState();
    loadData();
  }

  Future<void> loadData() async {
    SharedPreferences prefs = await SharedPreferences.getInstance();
    setState(() {
      username = prefs.getString('username');
      age = prefs.getInt('age');
    });
  }

  Future<void> saveData() async {
    SharedPreferences prefs = await SharedPreferences.getInstance();
    await prefs.setString('username', 'JohnDoe');
    await prefs.setInt('age', 25);
    loadData();
  }

  [@override](/user/override)
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('SharedPreferences Example'),
      ),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: [
            Text('Username: $username'),
            Text('Age: $age'),
            ElevatedButton(
              onPressed: saveData,
              child: Text('Save Data'),
            ),
          ],
        ),
      ),
    );
  }
}
回到顶部