微信小程序实现下拉菜单效果

简介: 微信小程序实现下拉菜单效果

问题描述

下拉菜单的运用:

下拉菜单在各类网页,app或者小程序中都是比较常见的输入控件。下拉菜单的下拉选项的多少可以根据自身需求进行调节,常运用于时间范围选择,地点区域选择,价格区间选择,等等。提供下拉菜单的目的是帮助用户更快更准确的选择相关条件。下拉菜单的运用可以简化页面设计,节约空间,在一定程度上简化设计。其缺点可能就是相比于单项选项卡还不够直观,用户每次想要查看所选选项时都必须打开菜单对选项进行比较。

解决方案

基本框架:

微信小程序中是没有html中的下拉标签的,所以要实现下拉菜单功能就必须自己动手写拉。在index.wxml文件中,我们需要写好下拉菜单的基础框架,使用view创建下拉选择的菜单,这里创建三个菜单,需要注意的是要加上data-name属性,用于下面实现选择菜单后显示在选择框里。分别通过bindtap给“请选择”的view绑定bindShowMsg方法,给菜单的view绑定mySelect方法,用于在js中实现控制。其中bindtap就是点击事件在.wxml文件绑定。

<viewclass='list-msg2'bindtap='bindShowMsg'>

上述代码就是在一个组件的属性上添加bindtap并赋予一个值(一个函数名)。当点击该组件时, 会触发相应的函数执行。在后台.js文件中定义tapMessage函数.

index.wxml文件代码如下:

<viewclass='list-msg'>

    <viewclass='list-msg1'>

        <text>选择日期</text>

    </view>

<!--下拉框   -->

    <viewclass='list-msg2'bindtap='bindShowMsg'>

        <text>{{tihuoWay}}</text>

        <imagestyle='height:20rpx;width:20rpx;'src='/images/down.png'></image>

    </view>

<!-- 下拉需要显示的列表 -->

    <viewclass="select_box"wx:if="{{select}}">

        <viewclass="select_one"bindtap="mySelect"data-name="近两日">近两日</view>

        <viewclass="select_one"bindtap="mySelect"data-name="近一周">近一周</view>

        <viewclass="select_one"bindtap="mySelect"data-name="全部记录">全部记录</view>

    </view>

</view>

样式调整:

小程序里的样式设置与HTML基本类似,就不一一介绍了。这里我们就简单介绍一下@keyframes规则。在index.wxss文件中我们使用了如下代码,其作用是实现下拉过度效果,使用@keyframes动画实现菜单的渐变打开和关闭动画。

@keyframesmyfirst {

    from {

        height:0rpx;

    }

    to {

        height:210rpx;

    }

}

使用@keyframe实现下拉过度效果,以百分比来规定改变发生的时间,或者通过关键词“from” 和 “to”,等价于 0% 和 100%。0% 是动画的开始时间,100% 动画的结束时间。

js方法:

在index.js页面,编写两个方法,一个是bindShowMsg ()方法,另一个是mySelect方法,用于实现当选择了下拉的菜单后显示菜单内容。代码如下:

Page({

  /* 页面的初始数据    */

  data: {

    select: false,

    tihuoWay: '近两日'

  },

  /*生命周期函数--监听页面加载   */

  onLoad: function (options) {

  },

  bindShowMsg() {

    this.setData({

      select: !this.data.select

    })

  },

  mySelect(e) {

    var name = e.currentTarget.dataset.name

    this.setData({

      tihuoWay: name,

      select: false

    })

  },

  /*用户点击右上角分享 */

  onShareAppMessage: function () {

  }

})

编译小程序,预览小程序运行后的效果:



图4.1 效果图


目录
相关文章
|
移动开发 小程序 JavaScript
uni-app兼容app-h5-微信小程序——下拉菜单、搜索栏
uni-app兼容app-h5-微信小程序——下拉菜单、搜索栏
1489 0
uni-app兼容app-h5-微信小程序——下拉菜单、搜索栏
|
JSON JavaScript 小程序
微信小程序实现上拉下拉菜单
微信小程序实现上拉下拉菜单
1969 0
|
自然语言处理 搜索推荐 小程序
微信公众号接口:解锁公众号开发的无限可能
微信公众号接口是微信官方提供的API,支持开发者通过编程与公众号交互,实现自动回复、消息管理、用户管理和数据分析等功能。本文深入探讨接口的定义、类型、优势及应用场景,如智能客服、内容分发、电商闭环等,并介绍开发流程和工具,帮助运营者提升用户体验和效率。未来,随着微信生态的发展,公众号接口将带来更多机遇,如小程序融合、AI应用等。
|
8月前
|
消息中间件 人工智能 Java
抖音微信爆款小游戏大全:免费休闲/竞技/益智/PHP+Java全筏开源开发
本文基于2025年最新行业数据,深入解析抖音/微信爆款小游戏的开发逻辑,重点讲解PHP+Java双引擎架构实战,涵盖技术选型、架构设计、性能优化与开源生态,提供完整开源工具链,助力开发者从理论到落地打造高留存、高并发的小游戏产品。
|
9月前
|
小程序 JavaScript API
uni-halo + 微信小程序开发实录:我的第一个作品诞生记
这篇文章介绍了使用uni-halo框架进行微信小程序开发的过程,包括选择该框架的原因、开发目标以及项目配置和部署的步骤。
480 0
uni-halo + 微信小程序开发实录:我的第一个作品诞生记
|
12月前
|
小程序 前端开发 Android开发
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
2257 29
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
4074 7
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
4662 1
|
人工智能 开发框架 机器人
AstrBot:轻松将大模型接入QQ、微信等消息平台,打造多功能AI聊天机器人的开发框架,附详细教程
AstrBot 是一个开源的多平台聊天机器人及开发框架,支持多种大语言模型和消息平台,具备多轮对话、语音转文字等功能。
8472 38
AstrBot:轻松将大模型接入QQ、微信等消息平台,打造多功能AI聊天机器人的开发框架,附详细教程
|
人工智能 自然语言处理 小程序
技术小白如何利用DeepSeek半小时开发微信小程序?
通过通义灵码的“AI程序员”功能,即使没有编程基础也能轻松创建小程序或网页。借助DeepSeek V3和R1满血版模型,用户只需用自然语言描述需求,就能自动生成代码并优化程序。例如,一个文科生仅通过描述需求就成功开发了一款记录日常活动的微信小程序。此外,通义灵码还提供智能问答模式,帮助用户解决开发中的各种问题,极大简化了开发流程,让普通人的开发体验更加顺畅。
3809 11
技术小白如何利用DeepSeek半小时开发微信小程序?