json_view 0.2.2
json_view: ^0.2.2 copied to clipboard
A json preview package that has a not bad performance. lazy load json tree node that cause less jank. Support display large list json data like chrome dev tool.
example/lib/main.dart
import 'package:flutter/material.dart';
import 'package:json_view/json_view.dart';
import 'json_data.dart';
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
// This widget is the root of your application.
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'JsonView Demo',
theme: ThemeData(
colorScheme: ColorScheme.fromSeed(seedColor: Colors.teal),
),
darkTheme: ThemeData.dark(),
home: HomePage(),
);
}
}
class HomePage extends StatefulWidget {
HomePage({Key? key}) : super(key: key);
@override
_HomePageState createState() => _HomePageState();
}
class _HomePageState extends State<HomePage>
with SingleTickerProviderStateMixin {
int size = 100;
late TabController _tabController;
@override
void initState() {
super.initState();
_tabController = TabController(length: 2, vsync: this);
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text('JSON VIEW'),
bottom: TabBar(
tabs: [
Tab(text: 'Map'),
Tab(text: 'List'),
],
controller: _tabController,
),
),
body: TabBarView(
children: [
JsonView(json: getJsonData()),
JsonView(json: listJsonData()),
],
controller: _tabController,
),
);
}
}
class Item extends StatefulWidget {
final int index;
final VoidCallback onTap;
Item({Key? key, required this.index, required this.onTap}) : super(key: key);
@override
_ItemState createState() => _ItemState();
}
class _ItemState extends State<Item> {
@override
void initState() {
super.initState();
print('build${widget.index}');
}
@override
Widget build(BuildContext context) {
return ListTile(
onTap: widget.onTap,
title: Text(widget.index.toString()),
);
}
}