【微信小程序】底部弹出式搜索框

本文介绍了如何在微信开发者工具中使用VantWeapp组件库,添加搜索按钮和搜索框。首先,在app.json引入button和icon组件,然后在首页WXML中添加搜索按钮。接着,引入search、action-sheet和empty组件,创建搜索弹窗。通过绑定函数控制搜索框的显示和隐藏,实现搜索功能。
摘要由CSDN通过智能技术生成

微信开发者工具的准备工作详见: 【微信小程序】初始页面和导航栏

设计中会使用到Vant Weapp组件库,添加组件库的方法参照官网:Vant Weapp - 轻量、可靠的小程序 UI 组件库

注意:我的组件库的引入的位置为/miniprogram,官方教程的位置可能会报错。

第一步,在页面中添加搜索按钮。

在app.json中添加,

  "usingComponents": {

  }

引入button组件和icon组件,

  "usingComponents": {
    "van-button": "/miniprogram/miniprogram_npm/@vant/weapp/button/index",
    "van-icon": "/miniprogram/miniprogram_npm/@vant/weapp/icon/index",
  }

在首页的index.wxml中添加,

<!-- 搜索按钮 -->
<van-button icon="search" plain type="info" bindtap = "SearchUp"/>

bindtap后的SearchUp为点击按钮后触发的函数,用来触发下一步中的搜索框。

效果图:

第二步,添加搜索框。

在app.json的"usingComponents"中引入search组件,action-sheet组件,empty组件,

  "usingComponents": {
    "van-search": "/miniprogram/miniprogram_npm/@vant/weapp/search/index",
    "van-action-sheet": "/miniprogram/miniprogram_npm/@vant/weapp/action-sheet/index",
    "van-empty": "/miniprogram/miniprogram_npm/@vant/weapp/empty/index"
  }

在首页的index.wxml中添加,

<!-- 搜索弹窗 -->
<van-action-sheet show="{{ show }}" title=" " bind:close="onClose" bind:select="onSelect">
  <view>
    <van-search 
      value="{{ value }}"
      label="搜索"
      shape="round"
      placeholder="请输入搜索关键词"
      show-action
      bind:search="onSearch"
      bind:cancel="onCancel"
    />
    <van-empty description="搜索内容" />
  </view>
</van-action-sheet>

show后的show为数据名称,需要到app.json的Page的data下添加并定义,

  data: {
    show: false
  },

van-search组件的:

bind:search="onSearch"

bind:cancel="onCancel"

这两个函数需要到app.json的Page下定义,

  onClose() {
    this.setData({ show: false });
  },

  onSelect(event) {
    console.log(event.detail);
  },
第三步,把搜索按钮和搜索框通过函数关联起来。

在app.json的Page下定义,

  SearchUp: function(){
    this.setData({show:true})
  },

这个函数的功能是在点击搜索按钮后,改变show的值,令搜索框由不可见转化为可见。

效果图:

这是手机预览的界面,开发者工具端的界面会有变形。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

MQiyirs

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值