可组合项 Card
用作您 UI 的 Material Design 容器。卡片通常呈现单个连贯的内容块。以下是一些您可能会使用卡片的示例:
- 购物应用中的产品。
- 新闻应用中的新闻报道。
- 通信应用中的消息。
正是对呈现单个内容块的关注,将 Card
与其他容器区分开来。例如,Scaffold
为整个屏幕提供了一般结构。卡片通常是较大布局中的较小 UI 元素,而像 Column
或 Row
这样的布局组件则提供更简单、更通用的 API。
基本实现
Card
的行为与 Compose 中的其他容器非常相似。您通过在其内部调用其他可组合项来声明其内容。例如,请看以下最小示例中 Card
如何包含对 Text
的调用:
@Composable
fun CardMinimalExample() {
Card() {
Text(text = "Hello, world!")
}
}
高级实现
有关 Card
的 API 定义,请参阅参考文档。它定义了几个参数,允许您自定义组件的外观和行为。
以下是一些需要注意的关键参数:
elevation
:为组件添加阴影,使其看起来高于背景。colors
:使用CardColors
类型设置容器和任何子项的默认颜色。enabled
:如果您为此参数传递false
,则卡片将显示为禁用状态,并且不响应用户输入。onClick
:通常,Card
不接受点击事件。因此,您需要注意的主要重载是定义onClick
参数的重载。如果您希望您的Card
实现响应用户的按压,则应使用此重载。
以下示例演示了您如何使用这些参数以及其他常见参数,例如 shape
和 modifier
。
填充卡片
以下是如何实现填充卡片的示例。
这里的关键是使用 colors
属性来更改填充颜色。
@Composable fun FilledCardExample() { Card( colors = CardDefaults.cardColors( containerColor = MaterialTheme.colorScheme.surfaceVariant, ), modifier = Modifier .size(width = 240.dp, height = 100.dp) ) { Text( text = "Filled", modifier = Modifier .padding(16.dp), textAlign = TextAlign.Center, ) } }
此实现显示如下:

高架卡片
以下代码片段演示了如何实现高架卡片。使用专用的 ElevatedCard
可组合项。
您可以使用 elevation
属性控制高架的外观和由此产生的阴影。
@Composable fun ElevatedCardExample() { ElevatedCard( elevation = CardDefaults.cardElevation( defaultElevation = 6.dp ), modifier = Modifier .size(width = 240.dp, height = 100.dp) ) { Text( text = "Elevated", modifier = Modifier .padding(16.dp), textAlign = TextAlign.Center, ) } }
此实现显示如下:

轮廓卡片
以下是轮廓卡片的示例。使用专用的 OutlinedCard
可组合项。
@Composable fun OutlinedCardExample() { OutlinedCard( colors = CardDefaults.cardColors( containerColor = MaterialTheme.colorScheme.surface, ), border = BorderStroke(1.dp, Color.Black), modifier = Modifier .size(width = 240.dp, height = 100.dp) ) { Text( text = "Outlined", modifier = Modifier .padding(16.dp), textAlign = TextAlign.Center, ) } }
此实现显示如下:

限制
卡片不自带固有的滚动或关闭操作,但可以集成到提供这些功能的可组合项中。例如,要在卡片上实现滑动关闭,请将其与 SwipeToDismiss
可组合项集成。要与滚动集成,请使用滚动修饰符,例如 verticalScroll
。有关更多信息,请参阅滚动文档。