更新记录

1.0.2(2024-06-07) 下载此版本

增加图标配置 高亮item定位到中间 增加动图说明 完善说明文挡

1.0.0(2024-06-06) 下载此版本

新增


平台兼容性

Vue2 Vue3
App 快应用 微信小程序 支付宝小程序 百度小程序 字节小程序 QQ小程序
HBuilderX 3.1.0 × × × ×
钉钉小程序 快手小程序 飞书小程序 京东小程序
× × × ×
H5-Safari Android Browser 微信浏览器(Android) QQ浏览器(Android) Chrome IE Edge Firefox PC-Safari
× × × × ×

hbxw-filter-navbar组件

介绍

过滤器navvar组件,过滤内容通过picker选择,超出可左右滚动

使用示例

使用前要以新建一个页面拷贝下面代码做一下测试,熟悉后再使用到项目中


<template>
    <view class="page-container">
        <hbxw-filter-navbar :filters="filters" @change="filterChange" />
        <view class="test-item">这是内容块1</view>
        <view class="test-item">这是内容块2</view>
        <view class="test-item">这是内容块3</view>
        <view class="test-item">这是内容块4</view>
        <view class="test-item">这是内容块5</view>
    </view>
</template>

<script>
    export default {
        data() {
            return {
                filters: [
                    {
                        name: '地区',
                        type: 'area',
                        // 是否高亮
                        isActive: false,
                        // 当前过滤项依赖的picker数据
                        pickerKey: 'name',
                        pickerValue: 'id',
                        pickerList: [
                            {
                                name: '全部',
                                id: -1
                            },
                            {
                                name: '广东',
                                id: 0
                            },{
                                name: '湖南',
                                id: 1
                            }
                        ]
                    },{
                        name: '状态类型',
                        type: 'status',
                        isActive: false,
                        pickerKey: 'name',
                        pickerValue: 'id',
                        pickerList: [
                            {
                                name: '全部',
                                id: -1
                            },
                            {
                                name: '待响应',
                                id: 0
                            },{
                                name: '已响应',
                                id: 1
                            }
                        ]
                    },{
                        name: '派单模式',
                        type: 'mode',
                        isActive: false,
                        pickerKey: 'name',
                        pickerValue: 'id',
                        pickerList: [
                            {
                                name: '全部',
                                id: -1
                            },
                            {
                                name: '征集',
                                id: 0
                            },{
                                name: '抢单',
                                id: 1
                            }
                        ]
                    },{
                        name: '测试模式',
                        type: 'test',
                        isActive: false,
                        pickerKey: 'name',
                        pickerValue: 'id',
                        pickerList: [
                            {
                                name: '全部',
                                id: -1
                            },
                            {
                                name: '征集',
                                id: 0
                            },{
                                name: '抢单',
                                id: 1
                            }
                        ]
                    },{
                        name: '测试模式0',
                        type: 'test0',
                        isActive: false,
                        pickerKey: 'name',
                        pickerValue: 'id',
                        pickerList: [
                            {
                                name: '全部',
                                id: -1
                            },
                            {
                                name: '征集',
                                id: 0
                            },{
                                name: '抢单',
                                id: 1
                            }
                        ]
                    }
                ]
            }
        },
        methods: {
            filterChange(res) {
                // 这里可以拿到过滤器返回的内容,做自己的一些处理即可
                const { pickerList, pickerValue,pickerItem, navIndex, navItem } = res;
                console.log('---- filterChange ----:', pickerList, pickerValue, pickerItem, navIndex, navItem)

                // 高亮操作,高亮当前过滤选项,其余的选项置灰
                const filtersClone = JSON.parse(JSON.stringify(this.filters));
                filtersClone.forEach((filterItem, filterIndex) => {
                    if (filterIndex === navIndex) {
                        filterItem.isActive = true;
                    } else {
                        filterItem.isActive = false;
                    }
                } )
                this.filters = filtersClone;
            }
        }
    }
</script>

<style>
.page-container{
    display: flex;
    flex-direction: column;
}
.test-item{
    width: 100%;
    height: 400rpx;
    display: flex;
    align-items: center;
    justify-content: center;
}
</style>

API

Props

属性名 类型 默认值 必填 说明
filters Array null 过滤器生成数据,详细请参考上面示例
activeColor String #287EFF 当前正在控制过滤项高亮的文本图标颜色
color String #111111 正常文本图标颜色
activeIcon String arrow-up 当前正在控制过滤项高亮的文本前图标,可使用图标
icon String arrow-down 非高亮时文本前图标
height String,Number 96rpx 过滤器高度
isFixed Boolean true 是否固定定位
zIndex Number 10 过滤器开启定位的时候如果遇到层组问题可调整此参数

Events

事件名 说明 返回值
change 过滤状态改变的时候触发的事件 对象{pickerList,pickerValue,pickerItem,navIndex,navItem},可依赖返回值做依赖过滤器的操作

注:该组件依赖uni-icons,安装完组件的时候在组件文件夹上右键-选择安装第三方依赖即可

隐私、权限声明

1. 本插件需要申请的系统权限列表:

2. 本插件采集的数据、发送的服务器地址、以及数据用途说明:

插件不采集任何数据

3. 本插件是否包含广告,如包含需详细说明广告表达方式、展示频率:

许可协议

MIT协议

使用中有什么不明白的地方,就向插件作者提问吧~ 我要提问