程序员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 悬浮按钮
      • 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 分段器
        • 介绍
          • 基本用法
        • API
          • SegmentedControl Props
          • SegmentedControl Events
        • 示例
      • uni-steps 步骤条
      • uni-swipe-action 滑动操作
      • uni-swiper-dot 轮播图指示点
      • uni-table 表格
      • uni-tag 标签
      • uni-title 章节标题
      • uni-tooltip 文字提示
      • uni-transition 过渡动画
  • 小程序开发
  • uniapp多端开发
  • 扩展组件
scholar
2024-10-21
目录

uni-segmented-control 分段器

组件名:uni-segmented-control

代码块: uSegmentedControl

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

用作不同视图的显示

# 介绍

# 基本用法

<template>
    <view>
        <uni-segmented-control :current="current" :values="items" @clickItem="onClickItem" styleType="button" activeColor="#4cd964"></uni-segmented-control>
        <view class="content">
            <view v-show="current === 0">
                选项卡1的内容
            </view>
            <view v-show="current === 1">
                选项卡2的内容
            </view>
            <view v-show="current === 2">
                选项卡3的内容
            </view>
        </view>
    </view>
</template>
<script>
export default {
  data() {
    return {
        ...
        items: ['选项1', '选项2', '选项3'],
        current: 0
    };
  },
  
  methods: {
    ...
    onClickItem(e) {
      if (this.current != e.currentIndex) {
        this.current = e.currentIndex;
      }
    }
  }
};
</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

# API

# SegmentedControl Props

属性名 类型 默认值 说明
current Number 0 当前选中的tab索引值,从0计数
styleType String button 分段器样式类型,可选值:button(按钮类型),text(文字类型)
activeColor String #007aff 选中的标签背景色与边框颜色
inActiveColor String transparent 未激活时的颜色
values Array - 选项数组

# SegmentedControl Events

事件名 说明 返回值
@clickItem 组件触发点击事件时触发 e={currentIndex}

# 示例

注意

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

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

    <template>
    	<view>
    		<uni-card is-full>
    			<text class="uni-h6">标签组件多用于商品分类、重点内容显示等场景。</text>
    		</uni-card>
    
    		<uni-section title="实心标签" type="line">
    			<view class="uni-padding-wrap uni-common-mt">
    				<uni-segmented-control :current="current" :values="items" :style-type="styleType"
    					:active-color="activeColor" @clickItem="onClickItem" />
    			</view>
    			<view class="content">
    				<view v-if="current === 0"><text class="content-text">选项卡1的内容</text></view>
    				<view v-if="current === 1"><text class="content-text">选项卡2的内容</text></view>
    				<view v-if="current === 2"><text class="content-text">选项卡3的内容</text></view>
    			</view>
    		</uni-section>
    
    		<uni-section title="Style" type="line"></uni-section>
    		<view class="example-body">
    			<radio-group class="uni-list" @change="styleChange">
    				<view v-for="(item, index) in styles" :key="index" class="uni-list-item">
    					<view class="uni-list-item__container">
    						<view class="uni-list-item__content">
    							<text class="uni-list-item__content-title">{{ item.text }}</text>
    						</view>
    						<view class="uni-list-item__extra">
    							<radio :value="item.value" :checked="item.checked" />
    						</view>
    					</view>
    				</view>
    			</radio-group>
    		</view>
    		<uni-section title="Color" type="line"></uni-section>
    		<view class="example-body">
    			<radio-group class="uni-list" @change="colorChange">
    				<view v-for="(item, index) in colors" :key="index" class="uni-list-item">
    					<view class="uni-list-item__container">
    						<view class="uni-list-item__content">
    							<view :style="{ backgroundColor: item }" class="color-tag" />
    						</view>
    						<view class="uni-list-item__extra">
    							<radio :value="item" :checked="index === colorIndex" />
    						</view>
    					</view>
    				</view>
    			</radio-group>
    		</view>
    	</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
    <script>
    	export default {
    		components: {},
    		data() {
    			return {
    				items: ['选项卡1', '选项卡2', '选项卡3'],
    				styles: [{
    						value: 'button',
    						text: '按钮',
    						checked: true
    					},
    					{
    						value: 'text',
    						text: '文字'
    					}
    				],
    				colors: ['#007aff', '#4cd964', '#dd524d'],
    				current: 0,
    				colorIndex: 0,
    				activeColor: '#007aff',
    				styleType: 'button'
    			}
    		},
    		methods: {
    			onClickItem(e) {
    				if (this.current !== e.currentIndex) {
    					this.current = e.currentIndex
    				}
    			},
    			styleChange(e) {
    				if (this.styleType !== e.detail.value) {
    					this.styleType = e.detail.value
    				}
    			},
    			colorChange(e) {
    				if (this.styleType !== e.detail.value) {
    					console.log(e.detail.value);
    					this.activeColor = e.detail.value
    				}
    			}
    		}
    	}
    </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
    <style lang="scss">
    	.example-body {
    		/* #ifndef APP-NVUE */
    		display: flex;
    		/* #endif */
    		flex-direction: row;
    		padding: 0;
    	}
    
    	.uni-common-mt {
    		margin-top: 30px;
    	}
    
    	.uni-padding-wrap {
    		// width: 750rpx;
    		padding: 0px 30px;
    	}
    
    	.content {
    		/* #ifndef APP-NVUE */
    		display: flex;
    		/* #endif */
    		justify-content: center;
    		align-items: center;
    		height: 150px;
    		text-align: center;
    	}
    
    	.content-text {
    		font-size: 14px;
    		color: #666;
    	}
    
    	.color-tag {
    		width: 25px;
    		height: 25px;
    	}
    
    	.uni-list {
    		flex: 1;
    	}
    
    	.uni-list-item {
    		/* #ifndef APP-NVUE */
    		display: flex;
    		/* #endif */
    		flex: 1;
    		flex-direction: row;
    		background-color: #FFFFFF;
    	}
    
    
    	.uni-list-item__container {
    		padding: 12px 15px;
    		width: 100%;
    		flex: 1;
    		position: relative;
    		/* #ifndef APP-NVUE */
    		display: flex;
    		box-sizing: border-box;
    		/* #endif */
    		flex-direction: row;
    		justify-content: space-between;
    		align-items: center;
    		border-bottom-style: solid;
    		border-bottom-width: 1px;
    		border-bottom-color: #eee;
    	}
    
    	.uni-list-item__content-title {
    		font-size: 14px;
    	}
    </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
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    // Make sure to add code blocks to your code group
    编辑此页 (opens new window)
    上次更新: 2025/02/03, 00:09:13
    uni-section 标题栏
    uni-steps 步骤条

    ← uni-section 标题栏 uni-steps 步骤条→

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