1.0.2 • Published 8 months ago
@tanzhenxing/zx-sidebar v1.0.2
zx-sidebar 侧边导航组件
垂直展示的导航栏,用于在不同的内容区域之间进行切换。
特性
- 🚀 支持 H5、小程序、App 多端适配
- 🎨 可自定义宽度和背景色
- 🔄 支持 v-model 双向绑定
- 🎯 支持徽标和小红点提示
- 🚫 支持禁用选项
基础用法
通过 v-model 绑定当前选中项的索引。
<template>
<zx-sidebar v-model="active">
<zx-sidebar-item title="标签名称" />
<zx-sidebar-item title="标签名称" />
<zx-sidebar-item title="标签名称" />
</zx-sidebar>
</template>
<script setup>
import { ref } from 'vue';
const active = ref(0);
</script>徽标提示
设置 dot 属性后,会在右上角展示一个小红点;设置 badge 属性后,会在右上角展示相应的徽标。
<template>
<zx-sidebar v-model="active">
<zx-sidebar-item title="标签名称" dot />
<zx-sidebar-item title="标签名称" badge="5" />
<zx-sidebar-item title="标签名称" />
</zx-sidebar>
</template>
<script setup>
import { ref } from 'vue';
const active = ref(0);
</script>禁用选项
通过 disabled 属性禁用选项。
<template>
<zx-sidebar v-model="active">
<zx-sidebar-item title="标签名称" />
<zx-sidebar-item title="标签名称" disabled />
<zx-sidebar-item title="标签名称" />
</zx-sidebar>
</template>
<script setup>
import { ref } from 'vue';
const active = ref(0);
</script>监听切换事件
设置 change 方法来监听切换导航项时的事件。
<template>
<zx-sidebar v-model="active" @change="onChange">
<zx-sidebar-item title="标签名 1" />
<zx-sidebar-item title="标签名 2" />
<zx-sidebar-item title="标签名 3" />
</zx-sidebar>
</template>
<script setup>
import { ref } from 'vue';
const active = ref(0);
const onChange = (index) => {
uni.showToast({
title: `标签名 ${index + 1}`,
icon: 'none'
});
};
</script>自定义宽度和背景色
通过 width 和 background 属性自定义侧边栏的样式。
<template>
<zx-sidebar v-model="active" width="100px" background="#f2f3f5">
<zx-sidebar-item title="标签名称" />
<zx-sidebar-item title="标签名称" />
<zx-sidebar-item title="标签名称" />
</zx-sidebar>
</template>
<script setup>
import { ref } from 'vue';
const active = ref(0);
</script>API
zx-sidebar Props
| 参数 | 说明 | 类型 | 默认值 |
|---|---|---|---|
| v-model | 当前导航项的索引 | number | string | 0 |
| width | 侧边栏宽度 | string | '80px' |
| background | 侧边栏背景色 | string | - |
zx-sidebar Events
| 事件名 | 说明 | 回调参数 |
|---|---|---|
| change | 切换导航项时触发 | index: number |
zx-sidebar-item Props
| 参数 | 说明 | 类型 | 默认值 |
|---|---|---|---|
| title | 内容 | string | '' |
| dot | 是否显示右上角小红点 | boolean | false |
| badge | 图标右上角徽标的内容 | number | string | - |
| disabled | 是否禁用该项 | boolean | false |
zx-sidebar-item Events
| 事件名 | 说明 | 回调参数 |
|---|---|---|
| click | 点击时触发 | index: number |
zx-sidebar-item Slots
| 名称 | 说明 |
|---|---|
| title | 自定义标题 |
主题定制
样式变量
组件提供了下列 CSS 变量,可用于自定义样式:
/* 在App.vue的style标签中 */
page {
/* 侧边栏宽度 */
--zx-sidebar-width: 80px;
/* 侧边栏字体大小 */
--zx-sidebar-font-size: 14px;
/* 侧边栏行高 */
--zx-sidebar-line-height: 1.4;
/* 侧边栏文字颜色 */
--zx-sidebar-text-color: #323233;
/* 侧边栏禁用文字颜色 */
--zx-sidebar-disabled-text-color: #c8c9cc;
/* 侧边栏内边距 */
--zx-sidebar-padding: 20px 12px;
/* 侧边栏激活背景色 */
--zx-sidebar-active-color: #f2f3f5;
/* 侧边栏背景 */
--zx-sidebar-background: #f7f8fa;
/* 侧边栏选中字体粗细 */
--zx-sidebar-selected-font-weight: 500;
/* 侧边栏选中文字颜色 */
--zx-sidebar-selected-text-color: #323233;
/* 侧边栏选中边框宽度 */
--zx-sidebar-selected-border-width: 4px;
/* 侧边栏选中边框高度 */
--zx-sidebar-selected-border-height: 16px;
/* 侧边栏选中边框颜色 */
--zx-sidebar-selected-border-color: #1989fa;
/* 侧边栏选中背景 */
--zx-sidebar-selected-background: #ffffff;
}