当前位置: 首页 > news >正文

有多少网站可以推广业务阿里云个人网站建设

有多少网站可以推广业务,阿里云个人网站建设,台州网站设计公司网站,wordpress 虚拟主机在移动应用开发中,本地持久化存储是必不可少的功能。无论是保存用户登录状态、应用配置,还是缓存数据,合理选择存储方案都能提高应用的性能与用户体验。在 Flutter 中,常用的本地存储方式主要有两种:SharedPreferences…

在移动应用开发中,本地持久化存储是必不可少的功能。无论是保存用户登录状态、应用配置,还是缓存数据,合理选择存储方案都能提高应用的性能与用户体验。

在 Flutter 中,常用的本地存储方式主要有两种:SharedPreferencesHive

本文将带你快速了解这两种方式的特点,并通过简单的 Demo 展示如何使用它们。


🔹 1. SharedPreferences

1.1 简介

SharedPreferences 是 Flutter 提供的轻量级存储方式,底层使用 Key-Value 形式存储,适合存储少量配置信息。

1.2 使用步骤

  1. 添加依赖

# pubspec.yaml
dependencies:shared_preferences: ^2.2.2
  1. 示例代码

import 'package:flutter/material.dart';
import 'package:shared_preferences/shared_preferences.dart';class SharedPreferencesDemo extends StatefulWidget {@override_SharedPreferencesDemoState createState() => _SharedPreferencesDemoState();
}class _SharedPreferencesDemoState extends State<SharedPreferencesDemo> {String _username = "";Future<void> _saveData() async {final prefs = await SharedPreferences.getInstance();await prefs.setString("username", "FlutterUser");setState(() {_username = "FlutterUser";});}Future<void> _loadData() async {final prefs = await SharedPreferences.getInstance();setState(() {_username = prefs.getString("username") ?? "暂无数据";});}@overrideWidget build(BuildContext context) {return Scaffold(appBar: AppBar(title: Text("SharedPreferences Demo")),body: Center(child: Column(mainAxisAlignment: MainAxisAlignment.center,children: [Text("用户名:$_username"),ElevatedButton(onPressed: _saveData,child: Text("保存数据"),),ElevatedButton(onPressed: _loadData,child: Text("读取数据"),),],),),);}
}

🔹 2. Hive

2.1 简介

Hive 是 Flutter 社区非常流行的 NoSQL 本地数据库,支持持久化存储、加密和复杂数据结构,性能优于 SharedPreferences

2.2 使用步骤

  1. 添加依赖

# pubspec.yaml
dependencies:hive: ^2.2.3hive_flutter: ^1.1.0# 如果要存储复杂对象
# dev_dependencies:
#   hive_generator: ^2.0.1
#   build_runner: ^2.3.3
  1. 初始化 Hive

import 'package:flutter/material.dart';
import 'package:hive_flutter/hive_flutter.dart';void main() async {WidgetsFlutterBinding.ensureInitialized();await Hive.initFlutter();await Hive.openBox("settings");runApp(MyApp());
}class MyApp extends StatelessWidget {@overrideWidget build(BuildContext context) {return MaterialApp(title: "Hive Demo",home: HiveDemo(),);}
}class HiveDemo extends StatefulWidget {@override_HiveDemoState createState() => _HiveDemoState();
}class _HiveDemoState extends State<HiveDemo> {final box = Hive.box("settings");String _username = "暂无数据"; // 本地存储的用户名void _saveData() {box.put("username", "HiveUser");setState(() {_username = "HiveUser"; // 立即更新 UI});}void _loadData() {final value = box.get("username", defaultValue: "暂无数据");setState(() {_username = value;});}@overrideWidget build(BuildContext context) {return Scaffold(appBar: AppBar(title: Text("Hive Demo")),body: Center(child: Column(mainAxisAlignment: MainAxisAlignment.center,children: [Text("用户名:$_username"),ElevatedButton(onPressed: _saveData,child: Text("保存数据"),),ElevatedButton(onPressed: _loadData,child: Text("读取数据"),),],),),);}
}

2.3 封装 HiveService(存储数组示例)

在实际项目中,为了方便调用,可以对 Hive 进行二次封装,例如存储数组:

import 'package:hive/hive.dart';class HiveService {Future<void> saveArray(String key, List<dynamic> array) async {var box = await Hive.openBox('myBox');await box.put(key, array); // 保存数组}Future<List<dynamic>> getArray(String key) async {var box = await Hive.openBox('myBox');return box.get(key, defaultValue: []); // 获取数组,默认值为空列表}
}

这样,我们只需调用 HiveService().saveArray("users", ["张三", "李四"]) 即可保存数组,调用 HiveService().getArray("users") 即可获取,十分方便。


🔹 3. 对比总结

特性SharedPreferencesHive
存储方式Key-ValueNoSQL 本地数据库
适用场景配置项、布尔开关、少量数据列表、对象、大量本地数据
性能适合轻量存储高性能,支持大规模数据存储
数据类型基础类型(String/Int/Bool)支持复杂对象和数组
易用性简单易上手初学需要配置,但功能更强大
加密支持支持 AES 加密

结论

  • 如果只是存储登录状态或主题设置,用 SharedPreferences 就够了。

  • 如果需要存储数组、对象或大量数据,推荐使用 Hive,并可通过封装服务类提高代码复用性。

http://www.dtcms.com/a/495381.html

相关文章:

  • 【知识点总结】Vue2 与 Vue2 区别
  • 【CV】神经网络中哪些参数需要被学习?
  • Spring两大漏洞可导致泄露敏感信息及安全防护绕过(CVE-2025-41253/41254)
  • 了解一个文件签名验证工具——sigverif
  • 河北建筑网站江小白网络营销案例
  • 张家口网站建设开发网站开发案例教程
  • 【NestJS】class-transformer什么用
  • 【word多文档docx合并】
  • Endnote | word中加载项消失不见,如何处理?
  • 聊聊 Unity(小白专享、C# 小程序 之 图片播放器)
  • 查询个人房产信息网站查看wordpress密码破解
  • 做网站用什么框架dede淘宝客网站
  • 高级篇:Python脚本(101-150)
  • pdf解析工具---Miner-u 本地部署记录
  • 怎么快速做网站文章新乡个人网站建设价格
  • 关于.net网站开发外文书籍wordpress子标题
  • 基于OpenIddict6.4.0搭建授权认证服务
  • 中国建设银行网站企业北京网站维护一般价格多少
  • shell编程语言---正则表达式,grep
  • JoyAgent问数多表关联Bug修复
  • 网站建设投标书报价表高端网站设计思路
  • 【玩泰山派】8、泰山派安装armbian,玩armbian
  • 雄安建设集团 网站推荐个在广州做网站的
  • vue3加载shp文件 并地图上展示
  • 实战:用PyTorch构建你的第一个图像分类CNN模型
  • 淄博网站建设优化公司wordpress后台登录网址
  • 每日一个网络知识点:网络层NAT
  • 不花钱网站怎么做推广小程序同步wordpress
  • 哈尔滨站建好了吗做网站机构图用什么工具
  • 基于ArcGIS的生态敏感性分析案例 | 绿水青山就是金山银山