Flutter Json数据转为和自动生成模板代码

使用json_serializable插件生成模板代码

1.添加依赖库

打开跟目录pubspec.yaml文件添加依赖库:

dependencies:
	json_annotation: ^4.4.0//注解依赖
dev_dependencies:
	 json_serializable: ^6.1.4//json格式化
 	 build_runner: ^1.6.1

2.利用json生成模板代码可以使用网页https://caijinglong.github.io/json2dart/index.html

import 'package:json_annotation/json_annotation.dart';

//这个名字一定要跟模板代码的文件名一致
part 'category_mode.g.dart';


@JsonSerializable()
class CategoryBean extends Object {
   

  @JsonKey(name: 'categories')
  List<Categories> categories;

  @JsonKey(name: 'message')
  String message;

  CategoryBean(this.categories,this.message,
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Flutter 中可以使用以下方法保存 JSON 数据: 1. 使用 shared_preferences 插件保存数据到本地。这个插件提供了一种简单的 key-value 存储方式,可以用来保存 JSON 数据。以下是保存和读取 JSON 数据的示例代码: ```dart import 'package:shared_preferences/shared_preferences.dart'; import 'dart:convert'; // 保存 JSON 数据 saveData(Map<String, dynamic> data) async { SharedPreferences prefs = await SharedPreferences.getInstance(); String jsonData = json.encode(data); prefs.setString('jsonData', jsonData); } // 读取 JSON 数据 Future<Map<String, dynamic>> loadData() async { SharedPreferences prefs = await SharedPreferences.getInstance(); String jsonData = prefs.getString('jsonData'); if (jsonData == null) return null; return json.decode(jsonData); } ``` 2. 使用文件存储保存 JSON 数据Flutter 提供了一个文件操作类,可以将数据保存到文件中。以下是保存和读取 JSON 数据的示例代码: ```dart import 'dart:async'; import 'dart:convert'; import 'dart:io'; // 保存 JSON 数据 saveData(Map<String, dynamic> data) async { final file = await _localFile; String jsonData = json.encode(data); file.writeAsString(jsonData); } // 读取 JSON 数据 Future<Map<String, dynamic>> loadData() async { try { final file = await _localFile; String jsonData = await file.readAsString(); return json.decode(jsonData); } catch (e) { return null; } } Future<File> get _localFile async { final path = await getApplicationDocumentsDirectory(); return File('$path/data.json'); } ``` 以上是两种常用的保存 JSON 数据的方法,你可以根据自己的需要选择其中一种。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值