首页 > 其他分享 >flutter组件之GridView.builder()

flutter组件之GridView.builder()

时间:2023-10-20 10:01:43浏览次数:28  
标签:myProducts index GridView Flutter builder Dart 组件 flutter


flutter组件之GridView.builder()_ci

如果您的 Flutter 应用程序需要显示大量或无限数量项目的网格视图(例如,从 API 获取的产品列表),那么您应该使用GridView.builder()而不是GridView()。该**生成器()**只为那些确实可见,所以您的应用程序的性能将得到改善

例子

步骤:

  1. 生成一个包含 100.000 个虚拟产品的列表:
final List<Map> myProducts =
      List.generate(100000, (index) => {"id": index, "name": "Product $index"})
          .toList();

通过使用GridView.builder(),我们将在渲染像这样的超大列表时摆脱滞后。

2.实现网格视图:

GridView.builder(
            gridDelegate: SliverGridDelegateWithMaxCrossAxisExtent(
                maxCrossAxisExtent: 200,
                childAspectRatio: 3 / 2,
                crossAxisSpacing: 20,
                mainAxisSpacing: 20),
            itemCount: myProducts.length,
            itemBuilder: (BuildContext ctx, index) {
              return Container(
                alignment: Alignment.center,
                child: Text(myProducts[index]["name"]),
                decoration: BoxDecoration(
                    color: Colors.amber,
                    borderRadius: BorderRadius.circular(15)),
              );
            }),

截屏:

flutter组件之GridView.builder()_javascript_02

img

完整代码

main.dart 中的完整源代码:

import 'package:flutter/material.dart';

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

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      // Hide the debug banner
      debugShowCheckedModeBanner: false,
      title: 'Kindacode.com',
      home: HomeScreen(),
    );
  }
}

class HomeScreen extends StatelessWidget {
  final List<Map> myProducts =
      List.generate(100000, (index) => {"id": index, "name": "Product $index"})
          .toList();

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Kindacode.com'),
      ),
      body: Padding(
        padding: const EdgeInsets.all(8.0),
        child: GridView.builder(
            gridDelegate: SliverGridDelegateWithMaxCrossAxisExtent(
                maxCrossAxisExtent: 200,
                childAspectRatio: 3 / 2,
                crossAxisSpacing: 20,
                mainAxisSpacing: 20),
            itemCount: myProducts.length,
            itemBuilder: (BuildContext ctx, index) {
              return Container(
                alignment: Alignment.center,
                child: Text(myProducts[index]["name"]),
                decoration: BoxDecoration(
                    color: Colors.amber,
                    borderRadius: BorderRadius.circular(15)),
              );
            }),
      ),
    );
  }
}

结论

恭喜!在这一点上,您应该对在您的应用程序中实现 GridView 有更好的理解并感到更自在

最后

这里也为想要学习Flutter的朋友们准备了两份学习资料《Flutter Dart语言编程入门到精通》《Flutter实战》,从编程语言到项目实战,一条龙服务!!

《Flutter Dart 语言编程入门到精通》

  • 第一章 Dart语言基础
  • 第二章 Dart 异步编程
  • flutter组件之GridView.builder()_Dart_03

  • 第三章 异步之 Stream 详解
  • 第四章 Dart标准输入输出流
  • flutter组件之GridView.builder()_javascript_04

  • 第五章 Dart 网络编程
  • 第六章 Flutter 爬虫与服务端
  • flutter组件之GridView.builder()_开发语言_05

  • 第七章 Dart 的服务端开发
  • 第八章 Dart 调用C语言混合编程
  • 第九章 LuaDardo中Dart与Lua的相互调用
  • flutter组件之GridView.builder()_开发语言_06

《Flutter实战:第二版》

  • 第一章:起步
  • 第二章:第一个Flutter应用
  • 第三章:基础组件
  • 第四章:布局类组件
  • 第五章:容器类组件

flutter组件之GridView.builder()_flutter_07

  • 第六章:可滚动组件
  • 第七章:功能型组件
  • 第八章:事件处理与通知
  • 第九章:动画
  • 第十章:自定义组件
  • flutter组件之GridView.builder()_ci_08

  • 第十一章:文件操作与网络请求
  • 第十二章:Flutter扩展
  • 第十三章:国际化
  • 第十四章:Flutter核心原理
  • 第十五章:一个完整的Flutter应用
  • flutter组件之GridView.builder()_Dart_09


标签:myProducts,index,GridView,Flutter,builder,Dart,组件,flutter
From: https://blog.51cto.com/u_16163480/7946928

相关文章

  • flutter圆形相关
    1、本地图片Image.asset加载项目资源包的图片//先将图片拷贝到项目images目录中,然后在pubspec.yaml文件配置文件相对路径到assetsImage.asset('images/cat.jpg',width:200,height:200,)Image.file加载手机内置或外置存储的图片//加载Android平台的外置存储图片需......
  • 使用 Flutter 制作一个简单的笑话生成器应用程序
    在本教程中,我将向您展示如何使用Flutter制作一个简单的笑话生成器应用程序对于这个项目,我们将从RESTfulAPI获取数据API的链接:随机笑话对于这个项目,我不会关注应用程序的UI,我们只会关注如何从URL中获取数据,以及如何显示它们在我们开始之前,您必须将此包添加到您的pubspec.y......
  • 如何学习 Flutter?这篇文章帮你搞定
    先来看看全球开发者的一个使用情况91%的开发者认为Flutter缩短了构建和发布应用程序的时间85%的开发者认为Flutter使他们的应用程序比以前更漂亮85%的人认为Flutter使他们的应用比以前能在更多的平台上发布再来看看Flutter的定义Flutter是谷歌的移动UI框架,它可以快速......
  • 解决vue单页面程序经过hbuilder打包成apk后物理按键会直接退出程序的问题
    解决方法是在项目index.html文件中写入 <script>   document.addEventListener('plusready',function(){     varwebview=plus.webview.currentWebview();     plus.key.addEventListener('backbutton',function(){      ......
  • 使用hbuilder实现左右菜单联动功能
    <template><viewclass="cbcd"><scroll-viewscroll-yscroll-with-animationclass="u-tab-viewmenu-scroll-view":scroll-top="scrollTop"><viewv-for="(item,index)intabbar&qu......
  • DataGridView导出EXCEL
    publicclassexecl{///<summary>///导出EXECLDataGridViewX///</summary>///<paramname="dataGridView">DataGridViewX</param>///<paramname="IsVisible">是否导出隐......
  • 在Android Studio上使用flutter Intl插件快速实现国际化和多国语言
    Flutter实现国际化和多语言支持在Flutter中实现国际化和多语言支持通常涉及以下步骤:添加依赖库:首先,你需要添加flutter_localizations依赖库到你的pubspec.yaml文件中。这个库包含了Flutter国际化所需的核心功能。dependencies:flutter:sdk:flutterflutter_localiza......
  • flutter 使用webView
    第一步:安装webView#webviewwebview_flutter:^3.0.2第二步:写入页面SizedBox(width:Get.width,height:Get.height,child:Padding(padding:EdgeInsets.only(top:264.w),child:WebView(initialUrl:controller.url,......
  • Flutter/Dart第13天:Dart错误处理
    Dart官方文档:https://dart.dev/language/error-handling重要说明:本博客基于Dart官网文档,但并不是简单的对官网进行翻译,在覆盖核心功能情况下,我会根据个人研发经验,加入自己的一些扩展问题和场景验证。异常和Java一样,Dart也可以抛出异常,也可以捕获异常。Dart异常如果未被捕获,容易......
  • C#之重新绘制DataGridView的选择框
    ///<summary>///重新绘制DataGridView的选择框///</summary>///<paramname="sender"></param>///<paramname="e"></param>privatevoidDgvUrlPath_CellPainting(objectse......