Flutter 中的 Card 小部件:全面指南

Flutter 中的 Card 小部件:全面指南

在 Flutter 中,Card 是一个用于呈现内容的容器,它带有圆角边缘和阴影效果,常用于展示信息块,如用户头像、相册、笔记或任何需要突出显示的内容。Card 小部件提供了一种简单而直观的方式来增强应用的 UI 视觉效果。

基础用法

Card 小部件最基本的用法是包裹其他小部件,为其添加圆角和阴影:

dart 复制代码
Card(
  child: Text('Hello, World!'),
)

这将创建一个带有简单文本的卡片。

定制化属性

Card 提供了多种属性来定制其外观:

颜色和形状

  • color: 设置卡片的背景颜色。
  • shape: 设置卡片的形状,如圆角的大小。
dart 复制代码
Card(
  color: Colors.blueGrey,
  shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(10.0)),
  child: Text('Colored Card'),
)

边距和填充

  • margin: 设置卡片的外边距。
  • clipBehavior: 控制卡片的裁剪行为。
dart 复制代码
Card(
  margin: EdgeInsets.all(10.0),
  clipBehavior: Clip.antiAlias,
  child: Padding(
    padding: EdgeInsets.all(8.0),
    child: Text('Padded Card'),
  ),
)

装饰

通过 elevation 属性,可以设置卡片的阴影大小:

dart 复制代码
Card(
  elevation: 8.0,
  child: Text('Elevated Card'),
)

实例:自定义卡片

下面是一个使用 Card 创建自定义卡片的实例,其中包含了图片和文本:

dart 复制代码
Card(
  elevation: 5.0,
  shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(10.0)),
  child: Row(
    children: <Widget>[
      Image.network(
        'https://example.com/image.jpg',
        height: 100.0,
        width: 100.0,
        fit: BoxFit.cover,
      ),
      Expanded(
        child: Padding(
          padding: EdgeInsets.all(10.0),
          child: Text(
            'This is a custom card with an image and text.',
            textScaleFactor: 1.2,
          ),
        ),
      ),
    ],
  ),
)

卡片列表

Card 常与 ListView 结合使用,创建卡片列表:

dart 复制代码
ListView(
  children: <Widget>[
    Card(
      child: ListTile(
        title: Text('Card 1'),
        subtitle: Text('This is the subtitle of the first card.'),
      ),
    ),
    Card(
      child: ListTile(
        title: Text('Card 2'),
        subtitle: Text('This is the subtitle of the second card.'),
      ),
    ),
    // ... 更多卡片
  ],
)

高级布局

Card 可以嵌套使用,创建复杂的布局:

dart 复制代码
Card(
  margin: EdgeInsets.all(10.0),
  child: Column(
    children: <Widget>[
      Padding(
        padding: EdgeInsets.all(8.0),
        child: Text('Card Title'),
      ),
      Card(
        margin: EdgeInsets.zero,
        child: ListTile(
          title: Text('Inner Card'),
          subtitle: Text('This is an inner card inside the main card.'),
        ),
      ),
    ],
  ),
)

性能考虑

在列表中使用大量 Card 时,确保使用 ListView.builder 来实现懒加载,以提高性能:

dart 复制代码
ListView.builder(
  itemCount: items.length,
  itemBuilder: (context, index) {
    return Card(
      child: ListTile(
        title: Text(items[index]),
      ),
    );
  },
)

结语

Card 是 Flutter 中一个非常实用的小部件,它提供了一种快速且有效的方式来展示信息。通过合理使用 Card,你可以增强应用的 UI 视觉效果,同时保持布局的整洁和有序。掌握 Card 的使用,可以帮助你创建出既美观又实用的用户界面。

相关推荐
ALLIN1 天前
Flutter 三种方式实现页面切换后保持原页面状态
flutter
Dabei1 天前
Flutter 国际化
flutter
Dabei1 天前
Flutter MQTT 通信文档
flutter
Dabei1 天前
Flutter 中实现 TCP 通信
flutter
孤鸿玉1 天前
ios flutter_echarts 不在当前屏幕 白屏修复
flutter
前端 贾公子1 天前
《Vuejs设计与实现》第 16 章(解析器) 上
vue.js·flutter·ios
tangweiguo030519872 天前
Flutter 数据存储的四种核心方式 · 从 SharedPreferences 到 SQLite:Flutter 数据持久化终极整理
flutter
0wioiw02 天前
Flutter基础(②④事件回调与交互处理)
flutter
肥肥呀呀呀2 天前
flutter配置Android gradle kts 8.0 的打包名称
android·flutter
吴Wu涛涛涛涛涛Tao2 天前
Flutter 实现「可拖拽评论面板 + 回复输入框 + @高亮」的完整方案
android·flutter·ios