程序员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 卡片
      • 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 悬浮按钮
        • 介绍
          • 基本用法
        • API
          • Fab Props
          • Fab Events
        • 示例
      • 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-fab 悬浮按钮

组件名:uni-fab

代码块: uFab

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

点击可展开一个图形按钮菜单

# 介绍

注意事项

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

  • 不建议动态修改属性,可能会耗损部分性能。
  • 展开菜单暂不支持字体图标,使用图片路径时建议使用绝对路径,相对路径可能会有问题。
  • 选中状态要通过自己控制,如果不希望有选中状态,不处理 active 即可。
  • 展开菜单建议最多显示四个,如果过多对于小屏手机可能会超出屏幕。

# 基本用法

在 template 中使用组件

<template>
	<view>
		<uni-fab
			:pattern="pattern"
			:content="content"
			:horizontal="horizontal"
			:vertical="vertical"
			:direction="direction"
			@trigger="trigger"
		></uni-fab>
	</view>
</template>
1
2
3
4
5
6
7
8
9
10
11
12

# API

# Fab Props

属性名 类型 默认值 说明
pattern Object - 可选样式配置项
horizontal String 'left' 水平对齐方式。left:左对齐,right:右对齐
vertical String 'bottom' 垂直对齐方式。bottom:下对齐,top:上对齐
direction String 'horizontal' 展开菜单显示方式。horizontal:水平显示,vertical:垂直显示
popMenu Boolean true 是否使用弹出菜单
content Array - 展开菜单内容配置项

pattern配置项:

参数 类型 默认值 说明
color String #3c3e49 文字默认颜色
selectedColor String #007AFF 文字选中时的颜色
backgroundColor String #ffffff 背景色
buttonColor String #3c3e49 按钮背景色
icon String plusempty 自定义图标,图标来自 uni-icons

content配置项:

参数 类型 说明
iconPath String 图片路径
selectedIconPath String 选中后图片路径
text String 文字
active Boolean 是否选中当前

# Fab Events

参数 类型 说明
@trigger Function 展开菜单点击事件,返回点击信息
@fabClick Function 悬浮按钮点击事件

# 示例

注意

示例依赖了 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">uni-ui 规范颜色色板,通过内置样式快速指定元素前景和背景色。</text>
    		</uni-card>
    
    		<uni-section title="基本功能" subTitle="点击按钮,切换 fab 不同状态" type="line">
    			<view class="warp">
    				<button class="button" type="primary" @click="switchBtn(0)">切换菜单方向({{ directionStr }})</button>
    				<button class="button" type="primary" @click="switchBtn('left', 'bottom')">左下角显示</button>
    				<button class="button" type="primary" @click="switchBtn('right', 'bottom')">右下角显示</button>
    				<button class="button" type="primary" @click="switchBtn('left', 'top')">左上角显示</button>
    				<button class="button" type="primary" @click="switchBtn('left', 'top')">左上角显示</button>
    				<button class="button" type="primary" @click="switchBtn('right', 'top')">右上角显示</button>
    				<button class="button" type="primary" @click="switchColor">修改颜色</button>
    			</view>
    		</uni-section>
    		<uni-fab ref="fab" :pattern="pattern" :content="content" :horizontal="horizontal" :vertical="vertical"
    			:direction="direction" @trigger="trigger" @fabClick="fabClick" />
    	</view>
    </template>
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    <script>
    	export default {
    		components: {},
    		data() {
    			return {
    				title: 'uni-fab',
    				directionStr: '垂直',
    				horizontal: 'left',
    				vertical: 'bottom',
    				direction: 'horizontal',
    				pattern: {
    					color: '#7A7E83',
    					backgroundColor: '#fff',
    					selectedColor: '#007AFF',
    					buttonColor: '#007AFF',
    					iconColor: '#fff'
    				},
    				is_color_type: false,
    				content: [{
    						iconPath: '/static/image.png',
    						selectedIconPath: '/static/image-active.png',
    						text: '相册',
    						active: false
    					},
    					{
    						iconPath: '/static/home.png',
    						selectedIconPath: '/static/home-active.png',
    						text: '首页',
    						active: false
    					},
    					{
    						iconPath: '/static/star.png',
    						selectedIconPath: '/static/star-active.png',
    						text: '收藏',
    						active: false
    					}
    				]
    			}
    		},
    		onBackPress() {
    			if (this.$refs.fab.isShow) {
    				this.$refs.fab.close()
    				return true
    			}
    			return false
    		},
    		methods: {
    			trigger(e) {
    				console.log(e)
    				this.content[e.index].active = !e.item.active
    				uni.showModal({
    					title: '提示',
    					content: `您${this.content[e.index].active ? '选中了' : '取消了'}${e.item.text}`,
    					success: function(res) {
    						if (res.confirm) {
    							console.log('用户点击确定')
    						} else if (res.cancel) {
    							console.log('用户点击取消')
    						}
    					}
    				})
    			},
    			fabClick() {
    				uni.showToast({
    					title: '点击了悬浮按钮',
    					icon: 'none'
    				})
    			},
    			switchBtn(hor, ver) {
    				if (hor === 0) {
    					this.direction = this.direction === 'horizontal' ? 'vertical' : 'horizontal'
    					this.directionStr = this.direction === 'horizontal' ? '垂直' : '水平'
    				} else {
    					this.horizontal = hor
    					this.vertical = ver
    				}
    				this.$forceUpdate()
    			},
    			switchColor() {
    				this.is_color_type = !this.is_color_type
    				if (this.is_color_type) {
    					this.pattern.iconColor = '#aaa'
    					this.pattern.buttonColor = '#fff'
    				} else {
    					this.pattern.iconColor = '#fff'
    					this.pattern.buttonColor = '#007AFF'
    				}
    			}
    		}
    	}
    </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
    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
    <style lang="scss">
    	.warp {
    		padding: 10px;
    	}
    
    	.button {
    		margin-bottom: 10px;
    	}
    </style>
    
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    // Make sure to add code blocks to your code group
    编辑此页 (opens new window)
    上次更新: 2025/02/03, 00:09:13
    uni-easyinput 增强输入框
    uni-fav 收藏按钮

    ← uni-easyinput 增强输入框 uni-fav 收藏按钮→

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