当前位置: 首页 > news >正文

谷粒商城实战笔记-46-商品服务-API-三级分类-配置网关路由与路径重写

文章目录

  • 一,准备工作
    • 1,新增一级菜单
    • 2,新增二级菜单
  • 二,前端树形界面开发
    • 1,开发分类展示组件
  • 三,远程调用接口获取商品分类数据
    • 1,远程调用
    • 2,路由配置
  • 错误记录

本节的主要内容:

  • 前端调用三级分类接口,并树形展示

一,准备工作

  • 启动product服务
  • 启动renren-fast后台服务
  • 启动renren-fast-vue服务
  • 创建商品系统菜单

1,新增一级菜单

在左侧菜单栏创建商品系统菜单,这是renren-fast自带的功能,我们在页面上操作即可。

在这里插入图片描述

点击确定后,刷新页面,可以看到左侧多了一个一级菜单。

在这里插入图片描述

2,新增二级菜单

在商品系统下新增商品分类二级菜单。

在这里插入图片描述
注意,上级菜单一定要选择上一步创建的“商品系统”。

在这里插入图片描述

二,前端树形界面开发

要用原生的js和html开发一个树形展示界面是非常有挑战性的,但使用Vue和ElementUI,可以大大加速,在几分钟内完成开发。

1,开发分类展示组件

renren-fast-vue前端工程中,src->views->modules下新建文件夹product,然后在product文件夹下新建category.vue文件。

在这里插入图片描述

使用我们之前配置vue模板快速插入代码。


在ElementUI文档中找到树形控件,复制代码。

在这里插入图片描述

完整代码:

<template><el-tree:data="data":props="defaultProps"@node-click="handleNodeClick"></el-tree>
</template><script>
export default {components: {},props: {},data () {return {data: [{label: '一级 1',children: [{label: '二级 1-1',children: [{label: '三级 1-1-1'}]}]}],defaultProps: {children: 'children',label: 'label',},}},methods: {handleNodeClick (data) {console.log(data)},},
}
</script>
<style scoped>
</style>

点击菜单商品分类,就可以看到三级菜单了。

在这里插入图片描述

三,远程调用接口获取商品分类数据

1,远程调用

分类数据存储在数据库中,前端要调用接口获取数据后才能展示在页面上。

在category.vue的脚本中新增方法getDataList

methods: {handleNodeClick (data) {console.log(data)},// 获取分类数据getDataList () {this.dataListLoading = truethis.$http({url: this.$http.adornUrl('/product/category/list/tree'),method: 'get'}).then(({data}) => {console.log(data)this.dataListLoading = false})}},

在生命周期方法中调用这个方法。

created() {this.getDataList()  // 获取分类数据
}

2,路由配置

前端所有请求都通过网关转发给后台服务,所以要做两件事:

  • 前端的url要配置网关的IP和端口

在这里插入图片描述

  • 网关要配置路由策略将请求转发到响应的服务。
        - id: admin_routeuri: lb://renren-fastpredicates:- Path=/api/**filters:- RewritePath=/api/(?<segment>.*),/renren-fast/$\{segment}

错误记录

这一节出现了很多包依赖相关的错误,记录在此谷粒商城实战笔记-包依赖踩坑。

http://www.lryc.cn/news/407933.html

相关文章:

  • 简要了解sql注入
  • Java 扫雷游戏
  • vue3 命令运行窗口暴露网络地址,以及修改端口号
  • 由CANoe自带协议栈在TCP断开连接时同时发送两条FIN报文引起的注意事项
  • FastGPT部署和接入使用重排模型bce-reranker-base
  • Android笔试面试题AI答之线程Handler、Thread(2)
  • 某某物联rabbitmqhttp二轮充电桩协议充电协议对接
  • 黑马JavaWeb企业级开发(知识清单)03——HTML实现正文:排版(音视频、换行、段落)、布局标签(div、span)、盒子模型
  • Java | Leetcode Java题解之第283题移动零
  • Django REST Framework(十三)视图集-GenericViewSet
  • 《0基础》学习Python——第二十四讲__爬虫/<7>深度爬取
  • Python Pygame制作简单五子棋游戏
  • JS+H5在线文心AI聊天(第三方接口)
  • kafka源码阅读-ReplicaStateMachine(副本状态机)解析
  • 【MetaGPT系列】【MetaGPT完全实践宝典——如何定义单一行为多行为Agent】
  • Kolla-Ansible的确是不支持CentOS-Stream系列产品了
  • IDEA启动C:\Users\badboy\.jdks\corretto-17.0.7\bin\java.exe -Xmx700m报错
  • ctfshow298-300(java信息泄露,代码审计)
  • Java 基础 and 进阶面试知识点(超详细)
  • 【LabVIEW作业篇 - 5】:水仙花数、数组与for循环的连接
  • Kafka系列之如何提高消费者消费速度
  • mac安装Whisper
  • Linux:进程概述(什么是进程、进程控制块PCB、并发与并行、进程的状态、进程的相关命令)
  • Unity UGUI 之 坐标转换
  • 使用 uPlot 在 Vue 中创建交互式图表
  • SpringBoot 项目配置文件注释乱码的问题解决方案
  • TTS如何正确读AI缩写、金额和数字
  • python基础知识点(蓝桥杯python科目个人复习计划75)
  • 小技巧:如何在已知PDF密码情况下去掉PDF的密码保护
  • Java泛型的介绍和基本使用