【微信小程序】黑马优购--03分类页面

本文档详细介绍了微信小程序中分类页面的实现过程,包括接口数据与页面效果的关联、数据获取、页面渲染、菜单点击事件处理、缓存技术应用、列表置顶功能以及接口代码的优化,旨在提升用户体验和代码效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

5分类页面


接口文档

5.1接口数据和页面效果的关系

 

5.2分类页面获取数据

在JSON中

{
  "usingComponents": {
    "Searchlnput":"../../components/Searchlnput/Searchlnput"
  },
  "navigationBarTitleText": "商品分类"
}

 在JS中

// pages/category/category.js
// 0 引入用来发送请求的方法
import { request } from "../../request/index";
Page({

  /**
   * 页面的初始数据
   */
  data: {
     // 左侧的菜单数据
     leftMenuList:[],
     // 右侧的商品数据
     rightContent:[]
  },
  // 接口的返回数据
  Cates:[],

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    this.getCates();
  },
  // 获取分类数据
  getCates(){
    request({
      url:"https://api-hmugo-web.itheima.net/api/public/v1/categories"
    })
    .then(res=>{
      // console.log(res);
      this.Cates=res.data.message;

      // 构造左侧的大菜单数据
      let  leftMenuList=this.Cates.map(v=>v.cat_name);
      // 构造右侧的商品数据
      let rightContent=this.Cates[0].children
      this.setData({
        leftMenuList,
        rightContent
      })
    })
  }
})

5.3分类页面渲染

在wxml中

<!--pages/category/category.wxml-->
<view class="cates">
  <!-- 搜索框 开始 -->
  <Searchlnput></Searchlnput>
  <!-- 搜索框 结束 -->

  <!-- 商品列表 开始 -->
  <view class="cates_container">
    <!-- 左侧菜单 -->
    <scroll-view scroll-y class="left_menu">
      <view class="menu_item  {
  {index===currentIndex?'active':''}}" wx:for="{
  {leftMenuList}}" wx:key="*this">{
  {item}}</view>
    </scroll-view>
    <!-- 右侧商品内容 -->
    <scroll-view scroll-y class="right_content">
      <view class="goods_group" wx:for="{
  {rightContent}}" wx:for-index="index1" wx:for-item="item1">
        <view class="goods_title">
          <text class="delimiter">/</text>
          <text class="title">{
  {item1.cat_name}}</text>
          <text class="delimiter">/</text>
        </view>
        <view class="goods_list">
          <navigator wx:for="{
  {item1.children}}" wx:for-index="index2" wx:for-item="item2" wx:key&#
1.2. 结构化一下 1.3. 图形化一下 1.3.1. 运营商后台 1.3.2. 商家后台 1.3.3. 网前台 参考京东 2. 技术选型 前端:angularJS + Bootstrap 后台:SSM( springmvc+spring+mybatis) 数据库:mysql,使用mycat读写分离 发模式:SOA 服务中间件:dubbox,需要和zookeeper配合使用 注册中心:zookeeper 消息中间件:Activemq,使用spring-jms 负载均衡:nginx 搜索:solr集群(solrCloud),配合zookeeper搭建, 使用spring-data-solor 缓存:redis集群,使用spring-data-redis 图片存储:fastDFS集群 网静态化:freemarker 单点登录:cas 权限管理:SpringSecurity, 跨域:cros 支付:微信扫描 短信验证:阿里大于 密码加密:BCrypt 富文本:KindEditor 事务:声明式事务 任务调度:spring task 所有的技术,都可能涉及到为什么用?怎么用?用的过程中有什么问题? 3. 框架搭建 3.1. 前端 理解baseControler.js、base.js、base_pagination.js,以及每一个xxxController.js里面都公共的做了些什么。 baseControler.js 分配置 列表刷新 处理checkBox勾选 xxxControler.js 自动生成增删改查 base_pagination.js 带分 base.js 不带分 3.2. dao 使用了mybatis逆向工程 4. 模块发 逐个模块发就好 4.1. 学会评估模块难不难 一个模块难不难从几方面考虑。 涉及几张表? 1,2张表的操作还是没有什么难度的。 涉及哪些功能? 增删改查,批量删除。 前端展示? 分列表、树形、面包屑、三级联动、内容格式化。 4.2. 举几个简单模块的例子 4.2.1. 品牌管理 单表 分、新增、删除、修改 4.2.2. 规格管理 2张表 分、新增、删除、修改、显示化(显示列表内容的一部分) 4.2.3. 模板管理 2张表 分、新增、删除、修改、显示化(显示列表内容的一部分) 4.2.4. 分类管理 单表 4.2.5. 商家审核 单表 4.3. 举一个复杂模块 4.3.1. 商品新增 需要插入3张表,tb_goods、tb_goods_desc、tb_item 前端:三级联动、富文本、图片上传、动态生成内容 4.3.2. 商品修改 需要从3张表获取数据,然后进行回显。 4.4. 典型模块设计 4.4.1. 管理后台 商品新增、商品修改 4.4.2. 前台页面 搜索模块实现 物车模块实现 支付模块实现 秒杀模块实现 5. 发过程中问题&化 1.1. 登录 单点登录怎么实现 session怎么共享 1.2. 缓存 哪些场景需要用到redis redis存储格式的选择 怎么提高redis缓存利用率 缓存如何同步 1.3. 图片上传 图片怎么存储 图片怎么上传 1.4. 搜索 ​ 怎么实现 数据量大、 并发量高的搜索 怎么分词 1.5. 消息通知 ​ 哪些情况用到activeMq 1.6. 化 seo怎么化 怎么加快访问速度 1.7. 秒杀 ​ 怎么处理高并发 ​ 秒杀过程中怎么控制库存
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值