Skip to content

Tabs 选项卡

分隔内容上有关联但属于不同类别的数据集合。

参数

参数说明类型可选值默认值
modelValue / v-model选中的下标值或者列表项的 value 值string / number
height高度number80
list列表array
loop是否循环显示booleantrue
fill选项卡是否填充booleanfalse
gutter选项卡间隔number20
border是否带有下边框booleantrue
color激活的字体及浮标颜色string主色
un-color未激活的字体颜色string
background-color背景色string#fff
show-dropdown是否显示下拉框booleanfalse

方法

事件名称说明参数
refresh特殊情况下,重新刷新布局

示例

基础用法

html
<template>
	<cl-tabs v-model="active" :list="list"></cl-tabs>
</template>

<script lang="ts" setup>
	import { ref } from "vue";

	const active = ref<number>(0);

	const list = ref<any[]>([
		{
			label: "数码"
		},
		{
			label: "家电"
		},
		{
			label: "母婴"
		},
		{
			label: "潮牌"
		}
	]);
</script>

居中

配置 justify 参数

html
<template>
	<cl-tabs v-model="active" :list="list" justify="center"></cl-tabs>
</template>

<script lang="ts" setup>
	import { ref } from "vue";

	const active = ref<number>(0);

	const list = ref<any[]>([
		{
			label: "数码"
		},
		{
			label: "家电"
		},
		{
			label: "母婴"
		},
		{
			label: "潮牌"
		}
	]);
</script>

填充

配置 fill 参数

html
<template>
	<cl-tabs v-model="active" :list="list" fill></cl-tabs>
</template>

<script lang="ts" setup>
	import { ref } from "vue";

	const active = ref<number>(0);

	const list = ref<any[]>([
		{
			label: "数码"
		},
		{
			label: "家电"
		},
		{
			label: "母婴"
		},
		{
			label: "潮牌"
		}
	]);
</script>

下拉框

配置 show-dropdown 参数及添加 dropdown 插槽

html
<template>
	<cl-tabs v-model="active" :list="list" show-dropdown>
		<template #dropdown>
			<view class="dropdown">
				<cl-text
					:value="item.label"
					v-for="item in list"
					:key="item.value"
					:margin="10"
				></cl-text>
			</view>
		</template>
	</cl-tabs>
</template>

<script lang="ts" setup>
	import { ref } from "vue";

	const active = ref<number>(0);

	const list = ref<any[]>([
		{
			label: "数码"
		},
		{
			label: "家电"
		},
		{
			label: "母婴"
		},
		{
			label: "潮牌"
		}
	]);
</script>

<style lang="scss" scoped>
	.dropdown {
		background-color: #ddd;
		padding: 20rpx;
	}
</style>

更改绑定值

list 中不存在 value 的情况下,会以数组的下标返回。否则返回 value

html
<template>
	<cl-tabs v-model="active" :list="list"></cl-tabs>
</template>

<script lang="ts" setup>
	import { ref } from "vue";

	const active = ref<string>("b");

	const list = ref<any[]>([
		{
			label: "数码",
			value: "a"
		},
		{
			label: "家电",
			value: "b"
		},
		{
			label: "母婴",
			value: "c"
		},
		{
			label: "潮牌",
			value: "d"
		}
	]);
</script>