微信小程序实现搜索框功能及踩过的坑


Posted in Javascript onJune 19, 2020

先上代码:

wxml:

<!-- 顶部搜索框 -->
<view class="inputcontainer">
 <view class="input" catchtap="inputSwitchStatus" wx:if="{{!edit}}">搜索商品</view>
 <view class="edit" wx:else>
  <form bindsubmit="inputSearch" bindreset="inputReset">
  <text class="searchicon"></text>
  <input focus="true" type="text" name="search-input" confirm-type='search' bindconfirm="inputSearch"/>
  <button class="deleteicon cancel-btn-default-style" catchtap="inputReset" hover-class="clear-btn-hover" formType="reset"></button>
  <button class="cancel cancel-btn-default-style" hover-class="search-btn-hover" formType="submit">搜索</button>
  </form>  
 </view> 
</view>

效果:

 微信小程序实现搜索框功能及踩过的坑 

上面两张图片分别是搜索框的两种状态,非搜索状态和搜索状态,样式很简单,逻辑也不复杂,但是小程序的搜索和网页的不一样,网页可以直接添加点击事件但是,小程序不行,因为小程序的搜索和输入分开,如果使用data-的话无疑会产生很多多余的代码,庆幸的是小程序提供了form可以整合搜索和输入,具体和已参考官方API。
本文主要讲的是踩过的坑,
①搜索和重置必须使用按钮,因为要使用button的formType。
②搜索事件和重置事件是绑定到form上的,而不是button。
③input必须添加一个name属性,例如name=”search-input”,否则你是用e.detail.value是取不到值的
④confirm-type='search'是控制你的软键盘的右下角显示的文字
⑤到目前为止你的搜索按钮可以正常使用,但是点击的软键盘的搜索按钮,没有任何效果,如果想要软键盘的搜索按钮同样可以使用,首先在输入框中添加indconfirm=”inputSearch”事件,然后测试你会发现,现在依然无法使用,但是却使用了函数,这是因为当你使用软键盘进行搜索时,获取的值的方式是e.detail.value就可以而不是e.detail.value‘search-input',所以你需要修改一下你的搜索函数:

inputSearch: function (e) { //输入框根据查询条件搜索点击事件
 // 获取用户输入框中的值
 let inputVaue = e.detail.value['search-input'] ? e.detail.value['search-input'] : e.detail.value;
 if (!inputVaue) {
  throw new Error('search input contents con not empty!');
  return ;
 }
 let searchUrl = "/product/index?keyword=" + inputVaue + "&fromindex=true";
 this.converterUrlAndRedirect(searchUrl);
 }

注意:

let inputVaue = e.detail.value[‘search-input'] ? e.detail.value[‘search-input'] : e.detail.value;
,现在你的小程序搜索框可以使用了。

另外有一个布局问题,ios的小程序对position: fixed;很不友好,所有尽量使用position: absolute;代替它

总结

到此这篇关于微信小程序实现搜索框功能及踩过的坑的文章就介绍到这了,更多相关微信小程序实现搜索框内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
尽可能写&quot;友好&quot;的&quot;Javascript&quot;代码
Jan 09 Javascript
JavaScipt中的Math.ceil() 、Math.floor() 、Math.round() 三个函数的理解
Apr 29 Javascript
jquery插件制作 表单验证实现代码
Aug 17 Javascript
浅谈javascript中this在事件中的应用
Feb 15 Javascript
jQuery+Ajax实现无刷新分页
Oct 30 Javascript
javascript实现保留两位小数的多种方法
Dec 18 Javascript
vue项目中做编辑功能传递数据时遇到问题的解决方法
Dec 19 Javascript
javascript中的深复制详解及实例分析
Dec 29 Javascript
详解webpack介绍&amp;安装&amp;常用命令
Jun 29 Javascript
node.js中Buffer缓冲器的原理与使用方法分析
Nov 23 Javascript
如何解决vue在ios微信&quot;复制链接&quot;功能问题
Mar 26 Javascript
JS实现简单打字测试
Jun 24 Javascript
微信小程序返回上一级页面的实现代码
Jun 19 #Javascript
小程序中的箭头函数的具体使用
Jun 19 #Javascript
在VUE style中使用data中的变量的方法
Jun 19 #Javascript
深入分析JavaScript 事件循环(Event Loop)
Jun 19 #Javascript
原生JS实现微信通讯录
Jun 18 #Javascript
vue+element-ui表格封装tag标签使用插槽
Jun 18 #Javascript
js实现ajax的用户简单登入功能
Jun 18 #Javascript
You might like
Breeze 文章管理系统 v1.0.0正式发布
2006/12/14 PHP
ThinkPHP 3.2 版本升级了哪些内容
2015/03/05 PHP
php简单计算年龄的方法(周岁与虚岁)
2016/12/06 PHP
PHP CURL采集百度搜寻结果图片不显示问题的解决方法
2017/02/03 PHP
Laravel5框架添加自定义辅助函数的方法
2018/08/01 PHP
LazyForm jQuery plugin 定制您的CheckBox Radio和Select
2009/10/24 Javascript
JQuery Dialog(JS 模态窗口,可拖拽的DIV)
2010/02/07 Javascript
JavaScript字符串常用类使用方法汇总
2015/04/14 Javascript
js实现兼容IE和FF的上下层的移动
2015/05/04 Javascript
微信小程序 location API接口详解及实例代码
2016/10/12 Javascript
浅谈js函数中的实例对象、类对象、局部变量(局部函数)
2016/11/20 Javascript
深入学习Bootstrap表单
2016/12/13 Javascript
完美解决node.js中使用https请求报CERT_UNTRUSTED的问题
2017/01/08 Javascript
详解JS构造函数中this和return
2017/09/16 Javascript
vue实现选项卡及选项卡切换效果
2018/04/24 Javascript
JavaScript事件对象深入详解
2018/12/30 Javascript
详解Vue中watch对象内属性的方法
2019/02/01 Javascript
JS中的算法与数据结构之队列(Queue)实例详解
2019/08/20 Javascript
解决layui的table插件无法多层级获取json数据的问题
2019/09/19 Javascript
vue-router的钩子函数用法实例分析
2019/10/26 Javascript
使用Python的内建模块collections的教程
2015/04/28 Python
Python多进程机制实例详解
2015/07/02 Python
定制FileField中的上传文件名称实例
2017/08/23 Python
用Python3创建httpServer的简单方法
2018/06/04 Python
Python实现登陆文件验证方法
2018/10/06 Python
Python 实现输入任意多个数,并计算其平均值的例子
2019/07/16 Python
对django 模型 unique together的示例讲解
2019/08/06 Python
TensorFlow2.1.0最新版本安装详细教程
2020/04/08 Python
BabyBjörn婴儿背带法国官网:BabyBjorn法国
2018/06/16 全球购物
经济信息管理专业大学生求职信
2013/09/27 职场文书
2014年机关后勤工作总结
2014/12/16 职场文书
商务考察邀请函模板
2015/02/02 职场文书
护士爱岗敬业心得体会
2016/01/25 职场文书
python中使用 unittest.TestCase单元测试的用例详解
2021/08/30 Python
分享一个vue实现的记事本功能案例
2022/04/11 Vue.js
Python中的matplotlib绘制百分比堆叠柱状图,并为每一个类别设置不同的填充图案
2022/04/20 Python