微信小程序首页的分类功能和搜索功能的实现思路及代码详解

就在昨天,微信宣布了微信小程序开发者工具新增“云开发”功能

下载最新的开发者工具,现在无需服务器即可实现小程序快速迭代!

分类功能和搜素功能效果

1.首页分类功能的实现

Boxtwo方法(.js文件

Boxtwo: function (e) { var index = parseInt(e.currentTarget.dataset.index) this.setData({ HomeIndex: index }) },

当在首页点击 分类导航时,会触发这个方法,并传回当前点击时的index值。

这个方法实现的是将.wxml文件传来的index值赋给HomeIndex。

class="Boxtwo-tab-nav {{HomeIndex == 0 ?'on':''}}"

.wxss样式文件

Boxtwo-tab-nav{ display: inline-block; width: 20%; height: 90rpx; line-height: 90rpx; border-bottom: 1rpx solid #ededed; Box-sizing: border-Box; text-align: center; color: black; font-size: 30rpx }

这样就实现了首页 当前点击的分类 呈现出 被选中的样式。

然后在视图层根据HomeIndex的不同,加载对应的数据。

组件实现的是点击当前文章时传出id到详情页面(detail)。这样就把首页文章列表文章的详情页面一一对应起来了。

detail.js文件

PHP?s=/addon/School/School/getDetail',data: {id:options.id},header: { 'content-type': 'application/json' },success: function (res) { wx.setStorage({ key: 'info',data: res.data,}) that.setData({ info: res.data }) } })

}

2.搜索功能的实现

.wxml文件

JavaScript indexOf() 方法

indexOf() 方法可返回某个指定的字符串值在字符串中首次出现的位置。

key为搜索的关键字,res.data[i].title为首页列表的标题。使用indexOf()方法时,当满足了(res.data[i].title.indexOf(key) >= 0)说明说明输入的关键字在文章列表

也有相同的关键字,然后arr.push(res.data[i]),这样就把筛选出来的文章放在了临时数组arr中了

= 0) {//查找 arr.push(res.data[i]) } } if (arr.length == 0) { that.setData({ newsList:[] }) } else { that.setData({ newsList: arr//在页面显示找到的数据 }) } } }) } //搜素时触发,调用search: function (key),传入输入的e.detail.value值 wxSearchInput: function (e) { this.search(e.detail.value); }

index.wxml(首页)完整代码

Boxtwo-tab-nav {{HomeIndex == 0 ?'on':''}}" bindtap="Boxtwo" data-index="0">首页 Boxtwo-tab-nav {{HomeIndex == 1 ?'on':''}}" bindtap="Boxtwo" data-index="1">资源分享 Boxtwo-tab-nav {{HomeIndex == 2 ?'on':''}}" bindtap="Boxtwo" data-index="2">微信小程序 Boxtwo-tab-nav {{HomeIndex == 3 ?'on':''}}" bindtap="Boxtwo" data-index="3">网赚小项目 Boxtwo-tab-nav {{HomeIndex == 4 ?'on':''}}" bindtap="Boxtwo" data-index="4">共享经济

index.wxss(对应的样式文件

Boxtwo-tab-nav{ display: inline-block; width: 20%; height: 90rpx; line-height: 90rpx; border-bottom: 1rpx solid #ededed; Box-sizing: border-Box; text-align: center; color: black; font-size: 30rpx } .on{ color:#405F80; border-bottom: 5rpx solid #405F80; } .infos{ float: left; width: 480rpx; height: 200rpx; padding: 20rpx 0 0 20rpx; } .date{ font-size:13px;color:#aaa;position: absolute; } .title{font-size: 15px;} .search{ float: left; width: 130rpx; height: 70rpx; margin-left: 0; background-color: blueviolet; font-size: 28rpx; color: #fff; border: none; } .input{ float: left; width: 500rpx; height: 70rpx; font-size: 35rpx; background-color: white; } .search-view{ position: relative; overflow: hidden; height: 70rpx; padding: 20rpx 20rpx 25rpx 60rpx; background-color: #6699FF; } .button-hover { background-color: red; }

.js文件(逻辑层)

= 0) {//查找 arr.push(res.data[i]) } } if (arr.length == 0) { that.setData({ newsList:[] }) } else { that.setData({ newsList: arr//在页面显示找到的数据 }) } } }) },//事件处理函数 bindViewTap: function() { wx.navigateTo({ url: '../logs/logs' }) },wxSearchInput: function (e) { this.search(e.detail.value); console.log(e.detail.value) },wxSerchFocus: function (e) { this.search(e.detail.value); },wxSearchBlur: function (e) { this.search(e.detail.value); },wxSearchFn: function (e) { /*console.log(e)*/ },Boxtwo: function (e) { var index = parseInt(e.currentTarget.dataset.index) this.setData({ HomeIndex: index }) },

总结

以上所述是小编给大家介绍的微信小程序首页分类功能搜索功能的实现思路及代码详解。编程之家 jb51.cc 收集整理的教程希望能对你有所帮助,如果觉得编程之家不错,可分享给好友!感谢支持

相关文章

1. 获取输入框数据wxml中的input上增加bindinput属性,和方法值在js部分定义与之对应的方法,只要在输入...
1.map组件的高度如果想要铺满屏幕,要是使用height:100vh样式2.获取位置要在app.json中标明权限3.先使用...
QQ小程序支付 Java后端 同学折腾QQ小程序的支付折腾了好几天,没有完成统一下单,因为我做过微信和支付...
前言: 在实际项目开发中我们经常会遇到账号统一的问题,如何在不同端或者是不同的登录方式下保证同一个...
一、前言: 我发现很多的同学都在抱怨说微信小程序的picker的mode = selector/mode = multiSelector 无...
前言: 之前自己做一个uni-app的项目的时候前端需要实现一个比较复杂的动态tab和swiper切换的功能,但是...