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


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 相关文章推荐
比较详细的关于javascript 解析json的代码
Dec 16 Javascript
基于jQuery的动态增删改查表格信息,可左键/右键提示(原创自Zjmainstay)
Jul 31 Javascript
jQuery中addClass()方法用法实例
Jan 05 Javascript
js实现类似jquery里animate动画效果的方法
Apr 10 Javascript
jquery任意位置浮动固定层插件用法实例
May 29 Javascript
微信小程序 地图map详解及简单实例
Jan 10 Javascript
微信小程序图片宽100%显示并且不变形
Jun 21 Javascript
解决vue2中使用axios http请求出现的问题
Mar 05 Javascript
Vue组件创建和传值的方法
Aug 17 Javascript
在vue项目中使用Jquery-contextmenu插件的步骤讲解
Jan 27 jQuery
JavaScript中AOP的实现与应用
May 06 Javascript
js实现随机点名
Jan 19 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
用PHP实现多服务器共享SESSION数据的方法
2007/03/16 PHP
在PHP中使用模板的方法
2008/05/24 PHP
PHP chmod 函数与批量修改文件目录权限
2010/05/10 PHP
PHP取得一个类的属性和方法的实现代码
2011/05/22 PHP
PHP+Mysql实现多关键字与多字段生成SQL语句的函数
2014/11/05 PHP
关于PHP5.6+版本“No input file specified”问题的解决
2019/12/11 PHP
tp5.1 框架数据库常见操作详解【添加、删除、更新、查询】
2020/05/26 PHP
破解Session cookie的方法
2006/07/28 Javascript
input 和 textarea 输入框最大文字限制的jquery插件
2011/10/27 Javascript
Knockout text绑定DOM的使用方法
2013/11/15 Javascript
jQuery在iframe中无法弹出对话框的解决方法
2014/01/12 Javascript
快速学习jQuery插件 Form表单插件使用方法
2015/12/01 Javascript
JavaScript通过代码调用Flash显示的方法
2016/02/02 Javascript
原生js实现addClass,removeClass,hasClass方法
2016/04/27 Javascript
Bootstrap的class样式小结
2016/12/01 Javascript
JS库之Highlight.js的用法详解
2017/09/13 Javascript
jQuery实现带右侧索引功能的通讯录示例【附源码下载】
2018/04/17 jQuery
vue嵌套路由与404重定向实现方法分析
2018/05/04 Javascript
jQuery实现模糊搜索功能的方法分析
2018/06/29 jQuery
vue-cli3全面配置详解
2018/11/14 Javascript
js实现计算器功能
2020/08/10 Javascript
鸿蒙系统中的 JS 开发框架
2020/09/18 Javascript
Python实现生成随机数据插入mysql数据库的方法
2017/12/25 Python
Python+matplotlib实现华丽的文本框演示代码
2018/01/22 Python
Python结合ImageMagick实现多张图片合并为一个pdf文件的方法
2018/04/24 Python
详解如何设置Python环境变量?
2019/05/13 Python
CSS3 @media的基本用法总结
2019/09/10 HTML / CSS
莫斯科隐形眼镜网上商店:Linzi
2019/07/22 全球购物
HOTEL INFO英国:搜索全球酒店
2019/08/08 全球购物
2014教师党员个人自我评议
2014/09/20 职场文书
顶岗实习计划书
2015/01/16 职场文书
区域销售经理岗位职责
2015/04/02 职场文书
2015年中秋寄语
2015/07/31 职场文书
2016年暑期见闻作文
2015/11/25 职场文书
tensorboard 可视化之localhost:6006不显示的解决方案
2021/05/22 Python
windows11怎么查看自己安装的版本号? win11版本号的查看方法
2021/11/21 数码科技