• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

微信小程序分类的实现

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

微信小程序的分类功能思路

实现思路

1.把屏幕当成一个固定的盒子,然后把盒子分成两边,并让盒子的每一边都能够滚动。
2.通过将左侧边栏元素的id和右边内容的categoryId进行匹配,渲染展示相同id的内容

页面data定义的初始数据

 /**
   * 页面的初始数据
   */
 data: {
    classify_sidebar: [], //左侧边栏内容的数组
    classify_content: [],  //右边内容元素的数组
    list: 124849,  //绑定切换时的id
  },

 

1.先利用文档对左边的侧边栏进行布局和渲染


<!-- 左侧边栏 -->
<scroll-view class="left"  scroll-y="true">
<view class="classify_sidebar">
<view class="{{item.id===list?\'classify_active\':\'\'}}" 
data-id="{{item.id}}" 
catchtap="change" 
wx:for=\'{{classify_sidebar}}\'   
wx:key="index">{{item.name}}</view>
</view>    
</scroll-view>

 


 class="{{item.id===list?\'classify_active\':\'\'}}"  
 运用三目运算符来给当前选中的元素切换样式(红色下划线),如果说当前元素的id和我们设置的list相同就添加类名加样式

 

data-id="{{item.id}}"  通过自定义来传参,根据左侧边栏元素的id来匹配右边的内容 
catchtap="change" 
当用户点击不同的侧边栏目录时候,根据 data-id 去从数据库获取新的数据,
渲染到左侧,并且修改 list的值,使新样式添加到点击的元素上

change(e) {
    let {id} = e.currentTarget.dataset
    this.contentFn(id) //封装的方法
    this.setData({
      list: id
    })
    wx.showLoading({
      title: \'加载中\',
    })
    setTimeout(() => {
      wx.hideLoading()
    }, 1000)
  },

 


2.右边内容的布局和渲染


<scroll-view  class="right" scroll-y="true">
<!-- 右边的内容部分 -->
<view class="classify_content">
<!-- 右边内容的列表 -->
<text wx:if="{{classify_content.length == 0}}">—————  暂无数据  ————</text>

<view class="classify_content_list" wx:if="{{classify_content.length > 0}}" wx:for="{{classify_content}}" wx:key="index">
<!-- 右边内容的列表图片 -->
<image src="{{item.pic}}"></image>
<text class="classify_content_list_right_title">{{item.name}}</text>
</view>
<!-- 右边内容的列表结束 -->
</view>
<!-- 右边的内容部分结束 -->
</scroll-view>
wx:if="{{classify_content.length == 0}}">

 


如果说右边相对应的商品数量为零就显示 “暂无数据”

 


//  封装
  contentFn(tar) {
    let arr = []
    wx.request({
      url: \'https://api.it120.cc/lsn/shop/goods/list\',
      success: res => {
        if (res.statusCode == 200) {
          res.data.data.forEach((item, v) => {
            if (item.categoryId == tar) {
              arr.push(item)
            }
          })
          this.data.classify_content = arr.reverse()
          this.setData({
            classify_content: this.data.classify_content
          })
        }
      }
    })
  },

思路
首先封装个方法然后在点击切换左侧边栏的时候进行调用
第一步:通过wx.request()去请求右边所有内容
第二步:如果说状态码200表示“服务器成功返回网页”
第三步:通过循环右边的内容,如果说当前categoryId等同于我们点击左侧边栏的id,数组push添加,同时倒序并且赋值给我们自己定义的数组和进行试图更新


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
app分享卡片跳小程序发布时间:2022-07-18
下一篇:
小程序中页面跳转路由传参发布时间:2022-07-18
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap