微信小程序原生的下拉框组件

news/2025/3/20 4:41:48/

前言

近日开发微信小程序时,需要一个下拉框的组件,使用和PC端下拉框一样的方式会显得很丑,于是发现微信官方API有个wx.showActionSheet,但是有诸多限制,例如:最大长度只能是6项,多选等等。

由于业务需要,下面用到下拉框(actionSheet)支持自定义 高度, 选项,单选,多选,以及遮罩层的透明度等参数。

效果

微信小程序原生的下拉框组件

看完效果直接上代码

组件代码

index.js

Component({properties: {//数据集options: {type: JSON,value: ''},//内容层高度topsHeight: {type: String,value: '40%'},//遮罩层透明度opacity: {type: String,value: '0.5'},//是否单选IsSingle: {type: Boolean,value: true}},data: {isShow: false,contentAnimate: null, //内容动画overlayAnimate: null, //遮罩层动画},methods: {/*** 关闭*/_close: function () {var that = this;this.contentAnimate.bottom("-40%").step();this.overlayAnimate.opacity(0).step();this.setData({contentAnimate: this.contentAnimate.export(),overlayAnimate: this.overlayAnimate.export(),});setTimeout(function () {that.setData({isShow: false,})}, 200)},/*** 显示*/_show: function () {var that = this;that.setData({isShow: true,})// 容器上弹var contentAnimate = wx.createAnimation({duration: 200,})contentAnimate.bottom(0).step();//遮罩层var overlayAnimate = wx.createAnimation({duration: 250,})overlayAnimate.opacity(`${this.properties.opacity}`).step();this.contentAnimate = contentAnimate;this.overlayAnimate = overlayAnimate;this.setData({contentAnimate: contentAnimate.export(),overlayAnimate: overlayAnimate.export(),})},/*** 设置选中*/_setSelect: function (even) {let data = this.data.options;let index = even.currentTarget.dataset.index;if (this.properties.IsSingle) {data.forEach((item, i) => {if (i == index) {item.Selected = !item.Selected;}else {item.Selected = false;}});}else {data[index].Selected = !data[index].Selected;}this.setData({options: data});},/*** 确定 * */_submit: function () {this.triggerEvent('OnSelectFinish', this.properties.options);this._close();},/*** 外部方法调用,显示组件*/showPopup: function () {this._show();}}
})

index.json

{"usingComponents": {},"component": true
}

index.wxml

<view class="selectComponent" style="height:{{topsHeight}};bottom: -{{topsHeight}};" wx:if="{{isShow}}" animation="{{contentAnimate}}">
<image src="../../images/icon_close_gray.png" class="close" catchtap="_close"></image><view class="select-ul"><view class="select-li" wx:for="{{options}}">{{item.Text}}<block wx:if="{{IsSingle}}"><view class="checkbox {{item.Selected ? 'singlechecked' : 'singleunchecked'}}" data-index="{{index}}" bindtap="_setSelect"></view></block><block wx:else><view data-single="{{IsSingle}}" class="checkbox {{item.Selected ? 'checked' : 'unchecked'}}" data-index="{{index}}" bindtap="_setSelect"></view></block></view></view><view class="SubmitBtn" bindtap="_submit">确 定</view>
</view>
<!-- 遮罩层 -->
<view class="overlay" catchtap ="_close" wx:if="{{isShow}}" animation="{{overlayAnimate}}"></view>

index.wxss

.overlay{position: fixed;top: 0;left: 0;z-index: 1;width: 100%;height: 100%;background-color: rgba(0, 0, 0);
}.selectComponent{background-color: white;position: fixed;/* bottom: -40%; */left: 0;width: calc( 100% - 100rpx);/* height: 40%; */z-index: 10000;padding:20rpx 50rpx;border-top-right-radius: 20rpx;border-top-left-radius: 20rpx;
}
.SubmitBtn{border-top: 10px #F7F8FA solid;height: 120rpx;text-align: center;line-height: 90rpx;position: absolute;bottom: 0;left: 0;width: 100%;background-color: #4876F9;color: white;
}
.select-ul{height: calc( 100% - 200rpx);overflow: auto;margin-top: 50rpx;
}
.select-li{text-align: left;line-height: 80rpx;height: 80rpx;position: relative;font-size: 14px;
}
.checkbox{top:24rpx !important;right: 30rpx !important;height: 34rpx;
}
.close{width: 14px;height: 14px;position: absolute;right: 30rpx;top: 30rpx;
}
.checkbox{width: 30rpx;height: 30rpx;top: 58rpx;right: 0rpx;position: absolute;background-repeat: no-repeat;background-size: 30rpx;
}
.singlechecked{background-image: url("");  
}
.singleunchecked{background-image: url("");  
}
.checked{background-image: url("");  
}
.unchecked{background-image: url("");  
}

调用页面代码

index.wxml

<!-- 出库类型下拉框 -->
<select id="select" options="{{options}}"  topsHeight="{{topsHeight}}" opacity="{{opacity}}" IsSingle="{{IsSingle}}" 
bind:OnSelectFinish="SelectFinish"></select>

json文件需要引用组件

{"usingComponents": {"select":"../../../../components/select/index"}
}

js 文件

const app = getApp();
Page({/*** 页面的初始数据*/data: {options: [], //数据集topsHeight: "30%", //高度opacity: "0.5", //透明度IsSingle: true //是否单选},/*** 生命周期函数--监听页面加载*/onLoad: function (options) {//初始化出库类型this.initExitType();},/*** 初始化出库类型*/initExitType() {/* 这里是系统封装的函数,下面需要换成自己的访问代码*/var that = this;HTTP.GetExitTypeList().then((res) => {if (res.ErrorCode === 0) {var newArray = [];res.Data.forEach(item => {newArray.push({ "Text": item.Text, "Value": item.Value });});that.setData({options: res.Data});}})},/*** 下拉框选择完成事件*/SelectFinish: function (even) {console.log(even.detail)},/*** 显示出库类型下拉框*/selectStockOutType: function () {this.selectComponent("#select").showPopup();}
})

效果图

微信小程序原生的下拉框组件


http://www.ppmy.cn/news/127468.html

相关文章

GFCC

声学特征: GFCC 1. introduction ASA CASA 2. Auditory Features input&#xff08;signal&#xff09; -> STFT -> Gammatone filters -> downsampling&#xff08;改变采样频率到10KHz&#xff09; -> loudness-compressed (减少 magnitude) -> output&am…

G1D54-CRF

一、CRF的输入X是什么&#xff1f;是构造的特征吗&#xff1f; 如此&#xff0c;CRF的x只用于状态函数吗&#xff1f; CRF的例子解释调用代码 机器之心 知乎忆榛 此处线性链条件随机场的特征函数形式被统一了&#xff1f; BilstmCRF&#xff0c;强烈推荐&#xff01;&#x…

GFS架构

1.GFS是什么 全称是Google File System&#xff0c;Google早期研发的分布式文件系统。 画外音&#xff1a;与分布式文件系统对应的&#xff0c;是单机文件系统&#xff0c;Windows和Linux操作系统都有文件系统。 GFS的设计目标是什么 主要有四个目标&#xff1a; (1) 高可用…

5GC NEF网元功能介绍

IPLOOK 5GC满足3GPP标准&#xff0c;具有更高的速率、更低的时延、支持更高的移动性和更大的连接数等特性。 IPLOOK 5GC系统架构相比4G EPC整体网络架构具有大幅度变化&#xff0c;采用基于云的微服务架构&#xff0c;将传统的网元转换为网络功能(NF)&#xff0c; 同时软硬件分…

5GC学习笔记之NF功能简介

参考&#xff1a;协议3GPP 23.501目录 1. AUSF 2. AMF 3. DN 4. UDM 5. UDR 6. UDSF 7. NEF 8. NRF 9. NSSAAF 10. NSSF 11. PCF 12. SMF 13. UPF 14. UCMF 15. AF 16. UE 17. 5G-EIR 18. NWDAF 19. CHF 20. SCP 21. SEPP 22. N3IWF 23. TNGF 24. W-AGF 25. TWIF 1. AUSF AUSF…

基于卷积神经网络的图像去噪(入门篇)

基于卷积神经网络的图像去噪&#xff08;基础篇&#xff09; 基础理论知识了解 基于深度学习的图像去噪&#xff0c;区别于传统去噪&#xff0c;但也有一定发展历程。从浅层模型到深度模型&#xff0c;从含噪图像映射去噪图像到含噪图像映射噪声图像&#xff08;也就是残差学…

fgfd

题记&#xff1a; 每当看到那些触目惊心的画面和文字&#xff0c;内心都是无比的气愤&#xff0c;曾今想着自己是茫茫社会洪流中的一粒沙砾&#xff0c;不可能改变世界&#xff0c;唯有独善其身&#xff0c;改变自己&#xff0c;让自己适应社会&#xff0c;不想到正是这种在很…

GFS存储

文章目录 一.GFS1.特点2.工作流程3.常用卷分类3.1分布式卷3.2条带卷3.3复制卷3.4 分布条带卷3.5 分布复制卷 二.总结 一.GFS GFS&#xff08;Gluster File System&#xff09; 是一个可扩展、开源的分布式文件系统&#xff08;可以很好的体现出弹性伸缩的特点&#xff09;&…