程序员scholar 程序员scholar
首页
  • Java 基础

    • JavaSE
    • JavaIO
    • JavaAPI速查
  • Java 高级

    • JUC
    • JVM
    • Java新特性
    • 设计模式
  • Web 开发

    • Servlet
    • Java网络编程
  • Web 标准

    • HTML
    • CSS
    • JavaScript
  • 前端框架

    • Vue2
    • Vue3
    • Vue3 + TS
    • 微信小程序
    • uni-app
  • 工具与库

    • jQuery
    • Ajax
    • Axios
    • Webpack
    • Vuex
    • WebSocket
    • 第三方登录
  • 后端与语言扩展

    • ES6
    • Typescript
    • node.js
  • Element-UI
  • Apache ECharts
  • 数据结构
  • HTTP协议
  • HTTPS协议
  • 计算机网络
  • Linux常用命令
  • Windows常用命令
  • SQL数据库

    • MySQL
    • MySQL速查
  • NoSQL数据库

    • Redis
    • ElasticSearch
  • 数据库

    • MyBatis
    • MyBatis-Plus
  • 消息中间件

    • RabbitMQ
  • 服务器

    • Nginx
  • Spring框架

    • Spring6
    • SpringMVC
    • SpringBoot
    • SpringSecurity
  • SpringCould微服务

    • SpringCloud基础
    • 微服务之DDD架构思想
  • 日常必备

    • 开发常用工具包
    • Hutoll工具包
    • IDEA常用配置
    • 开发笔记
    • 日常记录
    • 项目部署
    • 网站导航
    • 产品学习
    • 英语学习
  • 代码管理

    • Maven
    • Git教程
    • Git小乌龟教程
  • 运维工具

    • Docker
    • Jenkins
    • Kubernetes
  • 算法笔记

    • 算法思想
    • 刷题笔记
  • 面试问题常见

    • 十大经典排序算法
    • 面试常见问题集锦
关于
GitHub (opens new window)
首页
  • Java 基础

    • JavaSE
    • JavaIO
    • JavaAPI速查
  • Java 高级

    • JUC
    • JVM
    • Java新特性
    • 设计模式
  • Web 开发

    • Servlet
    • Java网络编程
  • Web 标准

    • HTML
    • CSS
    • JavaScript
  • 前端框架

    • Vue2
    • Vue3
    • Vue3 + TS
    • 微信小程序
    • uni-app
  • 工具与库

    • jQuery
    • Ajax
    • Axios
    • Webpack
    • Vuex
    • WebSocket
    • 第三方登录
  • 后端与语言扩展

    • ES6
    • Typescript
    • node.js
  • Element-UI
  • Apache ECharts
  • 数据结构
  • HTTP协议
  • HTTPS协议
  • 计算机网络
  • Linux常用命令
  • Windows常用命令
  • SQL数据库

    • MySQL
    • MySQL速查
  • NoSQL数据库

    • Redis
    • ElasticSearch
  • 数据库

    • MyBatis
    • MyBatis-Plus
  • 消息中间件

    • RabbitMQ
  • 服务器

    • Nginx
  • Spring框架

    • Spring6
    • SpringMVC
    • SpringBoot
    • SpringSecurity
  • SpringCould微服务

    • SpringCloud基础
    • 微服务之DDD架构思想
  • 日常必备

    • 开发常用工具包
    • Hutoll工具包
    • IDEA常用配置
    • 开发笔记
    • 日常记录
    • 项目部署
    • 网站导航
    • 产品学习
    • 英语学习
  • 代码管理

    • Maven
    • Git教程
    • Git小乌龟教程
  • 运维工具

    • Docker
    • Jenkins
    • Kubernetes
  • 算法笔记

    • 算法思想
    • 刷题笔记
  • 面试问题常见

    • 十大经典排序算法
    • 面试常见问题集锦
关于
GitHub (opens new window)
npm

(进入注册为作者充电)

  • 原生微信小程序

  • uniapp多端开发

    • 快速入门

    • 内置组件

    • 扩展组件

      • uni-ui 介绍
      • Uni-UI 的安装和使用
      • uni-sass 辅助样式
      • uni-badge 数字角标
      • uni-breadcrumb 面包屑
      • uni-calendar 日历
      • uni-card 卡片
        • 介绍
          • 基本用法
          • 卡片标题+额外信息
          • 双标题卡片 + 略缩图
          • 通栏卡片
          • 卡片封面图 + 操作栏
        • API
          • Card Props
          • Card Events
          • Card Slots
        • 示例
      • uni-collapse 折叠面板
      • uni-combox 组合框
      • uni-countdown 倒计时
      • uni-data-checkbox 数据选择器
      • uni-data-picker 级联选择器
      • uni-data-select 下拉框
      • uni-dateformat 日期格式化
      • uni-datetime-picker 日期选择器
      • uni-drawer 抽屉
      • uni-easyinput 增强输入框
      • uni-fab 悬浮按钮
      • uni-fav 收藏按钮
      • uni-file-picker 文件选择上传
      • uni-forms 表单
      • uni-goods-nav 商品导航
      • uni-grid 宫格
      • uni-group 分组
      • uni-icons 图标
      • uni-indexed-list 索引列表
      • uni-link 超链接
      • uni-list 列表
      • uni-load-more 加载更多
      • uni-nav-bar 自定义导航栏
      • uni-notice-bar 通告栏
      • uni-number-box 数字输入框
      • uni-pagination 分页器
      • uni-popup 弹出层
      • uni-rate 评分
      • uni-row 布局-行
      • uni-search-bar 搜索栏
      • uni-section 标题栏
      • uni-segmented-control 分段器
      • uni-steps 步骤条
      • uni-swipe-action 滑动操作
      • uni-swiper-dot 轮播图指示点
      • uni-table 表格
      • uni-tag 标签
      • uni-title 章节标题
      • uni-tooltip 文字提示
      • uni-transition 过渡动画
  • 小程序开发
  • uniapp多端开发
  • 扩展组件
scholar
2024-10-21
目录

uni-card 卡片

组件名:uni-card

代码块: uCard

点击下载&安装 (opens new window)

卡片组件通用来显示完整独立的一段信息,同时让用户理解他的作用。例如一篇文章的预览图、作者信息、时间等,卡片通常是更复杂和更详细信息的入口点。

# 介绍

注意事项

为了避免错误使用,给大家带来不好的开发体验,请在使用组件前仔细阅读下面的注意事项,可以帮你避免一些错误。

  • 因为平台兼容问题 , 目前 APP-NVUE 安卓平台下不支持阴影
  • 1.2.1 版本有较大改动 ,更新组件请注意组件兼容问题

# 基本用法

<uni-card>
	<text>这是一个基础卡片示例,内容较少,此示例展示了一个没有任何属性不带阴影的卡片。</text>
</uni-card>
1
2
3

# 卡片标题+额外信息

使用 title 属性设置卡片标题

使用 extra 属性设置卡片标题额外信息

<uni-card title="基础卡片" extra="额外信息">
	<text>这是一个基础卡片示例,此示例展示了一个标题加标题额外信息的标准卡片。</text>
</uni-card>
1
2
3

# 双标题卡片 + 略缩图

使用 sub-title 属性设置卡片副标题

使用 thumbnail 属性设置卡片标题左略缩图

<uni-card title="基础卡片" sub-title="副标题" extra="额外信息" thumbnail="https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/unicloudlogo.png">
	<text>这是一个带头像和双标题的基础卡片,此示例展示了一个完整的卡片。</text>
</uni-card>
1
2
3

# 通栏卡片

使用 is-full 属性设置卡片通栏 ,通栏没有外边距,左右会贴合父元素

<uni-card title="基础卡片" :isFull="true" sub-title="副标题" extra="额外信息">
	<text>这是一个通栏卡片 ,通栏没有外边距,左右会贴合父元素。</text>
</uni-card>
1
2
3

# 卡片封面图 + 操作栏

使用 cover 属性设置卡片封面图,或者使用 cover 插槽设置卡片封面图

使用 actions 插槽设置卡片操作栏内容,示例样式排版和事件需要自己实现

<uni-card cover="https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/unicloudlogo.png">
	<text>这是一个带封面和操作栏的卡片示例,此示例展示了封面插槽和操作栏插槽的用法。</text>
	<template v-slot:actions>
		<view class="card-actions">
			<view class="card-actions-item" @click="actionsClick('分享')">
				<uni-icons type="pengyouquan" size="18" color="#999"></uni-icons>
				<text class="card-actions-item-text">分享</text>
			</view>
			<view class="card-actions-item" @click="actionsClick('点赞')">
				<uni-icons type="heart" size="18" color="#999"></uni-icons>
				<text class="card-actions-item-text">点赞</text>
			</view>
			<view class="card-actions-item" @click="actionsClick('评论')">
				<uni-icons type="chatbubble" size="18" color="#999"></uni-icons>
				<text class="card-actions-item-text">评论</text>
			</view>
		</view>
	</template>
</uni-card>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19

# API

# Card Props

属性名 类型 默认值 说明
title String - 标题文字
sub-title String - 副标题文字
extra String - 标题额外信息
thumbnail String - 标题左侧缩略图,支持网络图片,本地图片,本图片需要传入一个绝对路径,如:/static/xxx.png
cover String - 封面图,支持网络图片,本地图片,本图片需要传入一个绝对路径,如:/static/xxx.png
is-full Boolean false 卡片内容是否通栏,为true时将去除padding值
is-shadow Boolean false 卡片内容是否开启阴影
shadow String 0px 0px 3px 1px rgba(0, 0, 0, 0.08) 卡片阴影,需符合 css 值
margin String 10px 卡片外边距
spacing String 10px 卡片内边距
padding String 10px 卡片内容内边距
border Boolean true 卡片边框
mode[弃用] String basic 卡片模式 ,可选值, basic:基础卡片 ;style :图文卡片 ; title :标题卡片
note[弃用] String - 底部信息

# Card Events

事件称名 事件说明 返回参数
@click 点击 Card 触发事件 -

# Card Slots

插槽称名 说明
cover 封面图插槽
title 卡片头部插槽,替换原header插槽
actions 操作栏插槽,替换原footer插槽
header[弃用] 卡片头部插槽( 图文卡片 mode="style" 时,不支持)
footer[弃用] 卡片底部插槽

# 示例

注意

示例依赖了 uni-card uni-section uni-scss 等多个组件,直接拷贝示例代码将无法正常运行 。

请到 组件下载页面 (opens new window) ,在页面右侧选择 使用 HBuilderX导入示例项目 ,体验完整示例演示 (opens new window)。

    <template>
    	<view class="container">
    		<uni-card :is-shadow="false" is-full>
    			<text class="uni-h6">卡片组件通用来显示完整独立的一段信息,同时让用户理解他的作用。例如一篇文章的预览图、作者信息、时间等,卡片通常是更复杂和更详细信息的入口点。</text>
    		</uni-card>
    		<uni-section title="基础卡片" type="line">
    			<uni-card :is-shadow="false">
    				<text class="uni-body">这是一个基础卡片示例,内容较少,此示例展示了一个没有任何属性不带阴影的卡片。</text>
    			</uni-card>
    		</uni-section>
    		<uni-section title="卡片标题+额外信息" type="line">
    			<uni-card title="基础卡片" extra="额外信息">
    				<text class="uni-body">这是一个基础卡片示例,此示例展示了一个标题加标题额外信息的标准卡片。</text>
    			</uni-card>
    		</uni-section>
    
    		<uni-section title="双标题卡片" type="line" >
    			<uni-card title="基础卡片" sub-title="副标题" extra="额外信息" :thumbnail="avatar" @click="onClick">
    				<text class="uni-body">这是一个带头像和双标题的基础卡片,此示例展示了一个完整的卡片。</text>
    			</uni-card>
    		</uni-section>
    
    		<uni-section title="通栏卡片" type="line">
    			<uni-card title="基础卡片" :isFull="true" sub-title="副标题" extra="额外信息" :thumbnail="avatar">
    				<text class="uni-body">这是一个通栏卡片 ,通栏没有外边距,左右会贴合父元素。</text>
    			</uni-card>
    		</uni-section>
    
    		<uni-section title="卡片封面图+操作栏" type="line">
    			<uni-card :cover="cover" @click="onClick">
    				<!-- <image slot='cover' style="width: 100%;" :src="cover"></image> -->
    				<text class="uni-body">这是一个带封面和操作栏的卡片示例,此示例展示了封面插槽和操作栏插槽的用法。</text>
    				<view slot="actions" class="card-actions">
    					<view class="card-actions-item" @click="actionsClick('分享')">
    						<uni-icons type="pengyouquan" size="18" color="#999"></uni-icons>
    						<text class="card-actions-item-text">分享</text>
    					</view>
    					<view class="card-actions-item" @click="actionsClick('点赞')">
    						<uni-icons type="heart" size="18" color="#999"></uni-icons>
    						<text class="card-actions-item-text">点赞</text>
    					</view>
    					<view class="card-actions-item" @click="actionsClick('评论')">
    						<uni-icons type="chatbubble" size="18" color="#999"></uni-icons>
    						<text class="card-actions-item-text">评论</text>
    					</view>
    				</view>
    			</uni-card>
    		</uni-section>
    
    		<uni-section title="自定义卡片内容" type="line">
    			<uni-card title="基础卡片" sub-title="副标题" extra="额外信息" padding="10px 0" :thumbnail="avatar" >
    				<template v-slot:title>
    					<uni-list>
    						<uni-list-item :show-switch="true" title="自定义标题"/>
    					</uni-list>
    				</template>
    				<image style="width: 100%;" :src="cover"></image>
    				<text class="uni-body uni-mt-5">卡片组件通用来显示完整独立的一段信息,同时让用户理解他的作用。例如一篇文章的预览图、作者信息、时间等,卡片通常是更复杂和更详细信息的入口点。</text>
    				<view slot="actions" class="card-actions">
    					<view class="card-actions-item" @click="actionsClick('分享')">
    						<uni-icons type="pengyouquan" size="18" color="#999"></uni-icons>
    						<text class="card-actions-item-text">分享</text>
    					</view>
    					<view class="card-actions-item" @click="actionsClick('点赞')">
    						<uni-icons type="heart" size="18" color="#999"></uni-icons>
    						<text class="card-actions-item-text">点赞</text>
    					</view>
    					<view class="card-actions-item" @click="actionsClick('评论')">
    						<uni-icons type="chatbubble" size="18" color="#999"></uni-icons>
    						<text class="card-actions-item-text">评论</text>
    					</view>
    				</view>
    			</uni-card>
    		</uni-section>
    
    		<uni-section title="卡片+列表" type="line">
    			<uni-card padding="0" spacing="0">
    				<template v-slot:cover>
    					<view class="custom-cover">
    						<image class="cover-image" mode="aspectFill" :src="cover">
    						</image>
    						<view class="cover-content">
    							<text class="uni-subtitle uni-white">今日新闻热点</text>
    						</view>
    					</view>
    				</template>
    				<uni-list>
    					<uni-list-item title="今日新闻" showArrow></uni-list-item>
    					<uni-list-item title="今日新闻" showArrow></uni-list-item>
    				</uni-list>
    				<view slot="actions" class="card-actions no-border">
    					<view class="card-actions-item" @click="actionsClick('分享')">
    						<uni-icons type="pengyouquan" size="18" color="#999"></uni-icons>
    						<text class="card-actions-item-text">分享</text>
    					</view>
    					<view class="card-actions-item" @click="actionsClick('点赞')">
    						<uni-icons type="heart" size="18" color="#999"></uni-icons>
    						<text class="card-actions-item-text">点赞</text>
    					</view>
    					<view class="card-actions-item" @click="actionsClick('评论')">
    						<uni-icons type="chatbubble" size="18" color="#999"></uni-icons>
    						<text class="card-actions-item-text">评论</text>
    					</view>
    				</view>
    			</uni-card>
    		</uni-section>
    
    
    	</view>
    </template>
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    <script>
    	export default {
    		components: {},
    		data() {
    			return {
    				cover: 'https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/shuijiao.jpg',
    				avatar: 'https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/unicloudlogo.png',
    				extraIcon:{
    					color: '#4cd964',
    					size: '22',
    					type: 'gear-filled'
    				}
    			}
    		},
    		methods: {
    			onClick(e){
    				console.log(e)
    			},
    			actionsClick(text){
    				uni.showToast({
    					title:text,
    					icon:'none'
    				})
    			}
    		}
    	}
    </script>
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    <style lang="scss">
    
    	.container {
    		overflow: hidden;
    	}
    
    	.custom-cover {
    		flex: 1;
    		flex-direction: row;
    		position: relative;
    	}
    
    	.cover-content {
    		position: absolute;
    		bottom: 0;
    		left: 0;
    		right: 0;
    		height: 40px;
    		background-color: rgba($color: #000000, $alpha: 0.4);
    		display: flex;
    		flex-direction: row;
    		align-items: center;
    		padding-left: 15px;
    		font-size: 14px;
    		color: #fff;
    	}
    
    	.card-actions {
    		display: flex;
    		flex-direction: row;
    		justify-content: space-around;
    		align-items: center;
    		height: 45px;
    		border-top: 1px #eee solid;
    	}
    	.card-actions-item {
    		display: flex;
    		flex-direction: row;
    		align-items: center;
    	}
    	.card-actions-item-text {
    		font-size: 12px;
    		color: #666;
    		margin-left: 5px;
    	}
    	.cover-image {
    		flex: 1;
    		height: 150px;
    	}
    	.no-border {
    		border-width: 0;
    	}
    </style>
    
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    // Make sure to add code blocks to your code group
    编辑此页 (opens new window)
    上次更新: 2025/02/03, 00:09:13
    uni-calendar 日历
    uni-collapse 折叠面板

    ← uni-calendar 日历 uni-collapse 折叠面板→

    Theme by Vdoing | Copyright © 2019-2025 程序员scholar
    • 跟随系统
    • 浅色模式
    • 深色模式
    • 阅读模式