微信小程序select下拉组件封装

本文介绍如何在微信小程序中封装一个自定义的select下拉组件,以满足设计需求。由于微信小程序的picker组件样式无法调整到理想状态,因此作者根据实际需求封装了一个组件,并展示了子组件的wxml和wxss代码,以及在页面上的使用方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

前言

刚接触微信小程序,之前有使用vue的底子,今天就分享一个自己封装的下拉组件(参考别人的组件按自己需求修改的),个人是不是很喜欢造轮子,如果有现成的都喜欢复制粘贴改改哈哈,都是之前公司养的坏毛病。

需求

项目需要一个下拉框进行数据筛选,微信小程序有提供自己的一个picker,但是跟我们设计需求不一样,微信小程序好像不支持select标签,如果支持,样式也改不到理想状态,所以最终还是封装了个组件。效果如下。

代码

子组件

component/select/select.wxml

<view class='com-selectBox'>
  <view class='com-sContent' bindtap='selectToggle'>
    <view class='com-sTxt'> {
  
  { nowText }}</view>
    <image src='../../img/arrow.png' class='com-sImg' animation="{
  
  {animationData}}"></image>
  </view>
  <view class='com-sList' wx:if="{
  
  {selectShow}}">
    <view wx:for="{
  
  {propArray}}" data-index="{
  <
微信小程序中实现下拉多选功能,可以通过自定义件或使用已有的第三方件库来完成。以下是一个基于自定义件的实现思路,并结合引用内容中的相关信息进行说明: ### 实现思路 1. **结构设计** 使用一个输入框显示选中的内容,旁边放置一个下拉箭头图标,点击后展开一个包含多个选项的弹窗。每个选项前可以放置复选框用于多选。 2. **数据绑定与事件处理** - `list`:传入可供选择的选项列表。 - `result`:保存当前选中的结果。 - `show`:控制下拉菜单的显示与隐藏。 - `checkSelected`:用于监听选中的值并触发事件。 3. **封装** 可以通过自定义件的方式将该功能封装成一个可复用的件。例如,在 `select-checkbox.js` 中定义件逻辑,如下所示: ```javascript // select-checkbox.js Component({ properties: { label: String, place: String, list: Array, checkSelected: { type: String, value: 'text' } }, data: { icon: 'arrow-down', show: false, result: [] }, methods: { // 点击下拉框展开/收起 toggleDropdown() { this.setData({ show: !this.data.show }); }, // 复选框选择 handleCheck(e) { const value = e.currentTarget.dataset.value; let result = [...this.data.result]; if (result.includes(value)) { result = result.filter(v => v !== value); } else { result.push(value); } this.setData({ result }); }, // 确定按钮事件 confirm() { this.setData({ show: false }); this.triggerEvent('sync', { value: this.data.result }); }, // 取消按钮事件 cancel() { this.setData({ show: false }); } } }); ``` 4. **样式调整** 将复选框的样式修改为圆形,可以通过 CSS 样式覆盖默认的 checkbox 样式,使其更符合 UI 设计需求。 5. **集成到页面中** 在页面的 JSON 文件中引入该件,并在 WXML 中使用它: ```json { "usingComponents": { "custom-select": "/components/select-checkbox/select-checkbox" } } ``` ```html <custom-select label="请选择" place="请选择选项" list="{{options}}" bind:sync="onSelectChange" /> ``` 6. **数据交互** 页面中通过 `onSelectChange` 方法接收件返回的选中项,并更新页面状态。 --- ### 注意事项 - **冒泡问题**:在实现过程中需要注意 checkbox 的点击事件优先级较高,可能会导致冒泡问题,建议在点击后重置事件流 [^1]。 - **封装件**:可以通过类似 `multipleSelection` 的封装方式,提高代码的复用性 [^2]。 - **树形结构支持**:如果需要支持嵌套的树形结构数据源,可以在件中增加对 `children` 字段的支持 [^4]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值