Skip to content

Subsection 分段器

该分段器一般用于用户从几个选项中选择某一个的场景

平台差异说明

App(vue)App(nvue)H5微信小程序

基本使用

  • 通过list数组参数传递分段的选项,数组元素可为字符串,或者通过keyName参数传入对象(默认为name)
  • 通过current指定初始化时激活的选项
html
<template>
  <su-subsection :list="list" :current="1"></su-subsection>
</template>

<script setup>
  import { ref } from 'vue'

  const list = ref(['未付款', '待评价', '已付款'])
  // 或者如果您想要使用对象数组
  // const list = ref([
  //   { name: '未付款' },
  //   { name: '待评价' },
  //   { name: '已付款' }
  // ]);

  const current = ref(1)
</script>

模式选择

通过mode设置分段器的模式

  • 值为button时为按钮类型
  • 值为subsection时为分段器形式
html
<su-subsection :list="list" v-model="current" mode="button"></su-subsection>

颜色配置

  • 通过activeColor配置激活选项的文字颜色
  • 通过inactiveColor配置未激活选项的文字颜色
  • 通过bgColor配置背景颜色,modebutton时有效(默认 '#eeeeef' )
html
<su-subsection activeColor="#f56c6c"></su-subsection>

注意事项

如果想通过一个变量绑定current值,需要在change事件回调中修改此值,否则可能会由于props的限制,前后两次设置current为相同的值, 而导致无法通过修改current值触发分段器的变化。

html
<template>
  <su-subsection :list="list" :current="curNow" @change="sectionChange"></su-subsection>
</template>
<script setup>
  import { ref } from 'vue'

  // 创建响应式引用
  const list = ref(['未付款', '待评价', '已付款'])
  const curNow = ref(0)

  // 定义方法,注意在 setup 中不需要 this,直接访问响应式引用
  function sectionChange(index) {
    curNow.value = index
  }
</script>

示例源码

点击可以查看 右侧演示页面的源码

API

Props

参数说明类型默认值可选值
list选项的数组,形式见上方"基本使用"Array--
current初始化时默认选中的选项索引值String | Number0-
active-color激活时的颜色String#3c9cff-
inactive-color未激活时的颜色String#303133-
mode模式选择,见上方"模式选择"说明Stringbuttonsubsection
font-size字体大小,单位rpxString | Number28-
bold激活选项的字体是否加粗Booleantruefalse
bg-color组件背景颜色,modebutton时有效String#eeeeef-
keyNamelist元素对象中读取的键名Stringname-

Events

事件名说明回调参数
change分段器选项发生改变时触发index:选项的index索引值,从0开始

Released under the MIT License.

Released under the MIT License.