- 我们先来看看小程序的官方文档
现附上小程序官网链接https://developers.weixin.qq.com/miniprogram/dev/index.html
在搜索框中输入input(点击即可查看哟)
你会发现很长很长的说明,对于很多初学者来说根本无从下手,咳咳,其实我也是小白,只是最近在负责一些小项目,也踩了一些坑,在这里和大家分享一下,哈哈哈哈哈.上图
![]()
![]()
![]()
![]()
首先我们得有一个思路, 在搜索框输入关键词,点击搜索按钮,进行搜索,当我们点击搜索时,会向服务器请求数据,那么,我们的思路是,我们输入的关键词与数据库数据进行匹配,如果有,则被调用出来
我们先把搜索框的基本样式给实现了,我们先建一个
search.wxml
<!-- 搜索框 -->
<view class='search'>
<input type='text' placeholder='输入你想要的内容' confirm-type='search' value="{{inputValue}}" bindinput='inputBind' bindconfirm='query'></input>
<image class="" src='/picture/search.png' bindtap='query'></image>
</view>
然后建一个
search.wxss
/* 搜索框样式 */
.search
{
display: flex;
flex-direction: row;
justify-content:space-between;
align-items: center;
width:70%;
height:60rpx;
background-color:whitesmoke;
margin-top: 5%;
border:1rpx solid whitesmoke;
border-radius: 5rpx;
}
/* 搜索框提示文字样式 */
.search input
{
font-size:27rpx;
font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
padding-left:30rpx;
}
/* 搜索框小图标 */
.search image
{
width:40rpx;
height:40rpx;
padding-right:20rpx;
}
最后建一个
search.js
page({
/**
* 页面的初始数据
*/
data:{
inputValue: '', //搜索的内容
},
//搜索框文本内容显示
inputBind: function(event) {
this.setData({
inputValue: event.detail.value
})
console.log('bindInput' + this.data.inputValue)
},
/**
* 搜索执行按钮
*/
query: function(event) {
var that = this
/**
* 提问帖子搜索API
* keyword string 搜索关键词 ; 这里是 this.data.inputValue
* start int 分页起始值 ; 这里是 0
*/
wx.request({
url: 'https://localhost/proj_online_class/server/public/index.php/forum/forum/get_issue_search/' + this.data.inputValue + /0/,
data: {
inputValue: this.data.inputValue
},
method: 'GET',
success: function(res) {
console.log(res.data)
var searchData = res.data
that.setData({
searchData
})
/**
* 把 从get_issue_searchAPI
* 获取 提问帖子搜索 的数据 设置缓存
*/
wx.setStorage({
key: 'searchLists',
data: {
searchLists: res.data
}
})
/**
* 设置 模糊搜索
*/
if (!that.data.inputValue) {
//没有搜索词 友情提示
wx.showToast({
title: '请重新输入',
image: '../../picture/tear.png',
duration: 2000,
})
} else if (searchData.search.length == 0) {
//搜索词不存在 友情提示
wx.showToast({
title: '关键词不存在',
image: '../../picture/tear.png',
duration: 2000,
})
} else {
//提取题目关键字 与搜索词进行匹配
var searchIndex = searchData.search.length
var d = 0;
for (var i = 0; i <= searchIndex - 1; i++) {
var searchTitle = searchData.search[d].title
console.log(searchTitle)
d = d + 1;
for (var x = 0; x <= searchTitle.length; x++) {
for (var y = 0; y <= searchTitle.length; y++) {
var keyWord = searchTitle.substring(x, y);
console.log(keyWord)
}
}
/**
* 根据关键词 跳转到 search搜索页面
*/
wx.navigateTo({
url: '../search/search',
})
}
}
}
})
}
})
![]()
文档中说可以替换输入的内容,那么我们来试一试,实践出珍珠嘛,哈哈哈,我们给它绑定一个事件,如图
![]()
把inputValue的值注册到date里面,如图
![]()
然后在把inputValue值给绑定在search.wxml,如图
![]()
注意,数据绑定得用“{{ }}”哟·,这一点是不是很Vue很像,哈哈哈,我也是刚学Vue
把内容输入进去后,是不是要点击搜索呀,我们很自然就想到需要一个按钮,我们把 bindconfirm=”query” 但它不是一个按钮,我之前老是点它没反应,哈哈哈,那它是干什么的呢,如图
![]()
原来它是点击完成时触发输入到搜索框的,soga,然后捏,然后就没有然后了,哈哈哈哈,不存在的,我们现在还缺一个按钮呀,我们就给它一个按钮用来点击搜索,我又想实现点击触发,我们该咋办捏,嘻嘻,可以通过中介,嘻嘻嘻,我们绑定一个按钮,如图
![]()
这个中介就是“query”啦,当我们点击时也可以触发bindconfirm啦这里,当然这里绑定按钮还可以选择catchtap=”query”,bindtap和catchtap有什么区别,前者是冒泡,后者是非冒泡,至于什么是冒泡和非冒泡,哈哈,我就不在这累述啦,感觉我好啰嗦,啊哈哈
当然,bindtap=”query”,点击,肯定得向服务器请求呀,所以在search.js中有
![]()
wx.request({})即向服务器请求的函数呐,把你的API写在url上,把你的搜索关键字写在data上,然后就万事大吉啦
可能这里写得比较绕,如图
![]()
首先说明,我也是个小白,所以写得并不好,我相信肯定有比这更好的写法,这段代码的意思是,把title给遍历一遍,然后与搜索词匹配
至于search是什么,是我填写在API的返回值呐,如图
![]()
好了,关于小程序的搜索大概就讲这么多啦