尚品汇-前端调用搜索实现(三十二)

目录:

(1)修改web-all模块

(2)配置网关

(3)页面渲染

(4)面包屑处理

(1)修改web-all模块

修改pom.xml文件



  <dependencies>

    <dependency>

        <groupId>com.atguigu.gmall</groupId>

        <artifactId>service-item-client</artifactId>

        <version>1.0</version>

    </dependency>

    <dependency>

        <groupId>com.atguigu.gmall</groupId>

        <artifactId>service-product-client</artifactId>

        <version>1.0</version>

    </dependency>

      <dependency>

        <groupId>com.atguigu.gmall</groupId>

        <artifactId>service-list-client</artifactId>

        <version>1.0</version>

    </dependency>

  </dependencies>

创建ListController控制器调用接口

package com.atguigu.gmall.all.controller;
/**
 * <p>
 * 产品列表接口
 * </p>
 *
 */
@Controller
public class ListController {

    @Autowired
    private ListFeignClient listFeignClient;

    /**
     * 列表搜索
     * @param searchParam
     * @return
     */
    @GetMapping("list.html")
    public String search(SearchParam searchParam, Model model) {
        Result<Map> result = listFeignClient.list(searchParam);
        model.addAllAttributes(result.getData());

        return "list/index";
    }
}

(2)配置网关

(3)页面渲染

页面渲染:1 列表显示

添加url参数 

 


<li class="yui3-u-1-5" th:each="goods: ${goodsList}">
    <div class="list-wrap">
        <div class="p-img">
            <a th:href="@{http://item.gmall.com/{id}.html(id=${goods.id})}" target="_blank"><img th:src="${goods.defaultImg}"/></a>
        </div>
        <div class="price">
            <strong>
                <em>¥</em>
                <i th:text="${goods.price}">6088.00</i>
            </strong>
        </div>
        <div class="attr">
            <a th:href="@{http://item.gmall.com/{id}.html(id=${goods.id})}" target="_blank" th:utext="${goods.title}">Apple苹果iPhone 6s (A1699)Apple苹果iPhone 6s (A1699)Apple苹果iPhone 6s (A1699)Apple苹果iPhone 6s (A1699)</a>
        </div>
        <div class="commit">
            <i class="command">已有<span>2000</span>人评价</i>
        </div>
        <div class="operate">
            <a href="javascript:void(0);" class="sui-btn btn-bordered btn-danger">自营</a>
            <a href="javascript:void(0);" class="sui-btn btn-bordered">收藏</a>
        </div>
    </div>
</li>

搜索条件处理

根据搜索对象SearchParam拼接url

ListController

@Autowired
private ListFeignClient listFeignClient;
@GetMapping("list.html")
public String search(SearchParam searchParam, Model model){
    Result<Map> list = listFeignClient.list(searchParam);
    model.addAllAttributes(list.getData());

    // 记录拼接url;
        String urlParam = makeUrlParam(searchParam);
    model.addAttribute("searchParam",searchParam);
    model.addAttribute("urlParam",urlParam);
    return "list/index";
}

// 制作返回的url
private String makeUrlParam(SearchParam searchParam) {
    StringBuilder urlParam = new StringBuilder();
    // 判断关键字
    if (searchParam.getKeyword()!=null){
        urlParam.append("keyword=").append(searchParam.getKeyword());
    }
    // 判断一级分类
    if (searchParam.getCategory1Id()!=null){
        urlParam.append("category1Id=").append(searchParam.getCategory1Id());
    }
    // 判断二级分类
    if (searchParam.getCategory2Id()!=null){
        urlParam.append("category2Id=").append(searchParam.getCategory2Id());
    }
    // 判断三级分类
    if (searchParam.getCategory3Id()!=null){
        urlParam.append("category3Id=").append(searchParam.getCategory3Id());
    }
    // 处理品牌
    if(searchParam.getTrademark()!=null){
        if (urlParam.length()>0){
            urlParam.append("&trademark=").append(searchParam.getTrademark());
        }
    }
    // 判断平台属性值
    if (null != searchParam.getProps()){
        for (String prop : searchParam.getProps()) {
            if (urlParam.length() > 0){
                urlParam.append("&props=").append(prop);
            }
        }
    }
    return "list.html?" + urlParam.toString();
}
  1. 平台属性处理
<div class="type-wrap" th:each="baseAttrInfo:${attrsList}" th:unless="${#strings.contains(urlParam, 'props='+baseAttrInfo.attrId)}">

    <div class="fl key" th:text="${baseAttrInfo.attrName}">网络制式</div>

    <div class="fl value">

        <ul class="type-list">

            <li th:each="attrValue:${baseAttrInfo.attrValueList}">

                <a href="" th:text="${attrValue}" >属性值111</a>

            </li>

        </ul>

    </div>

    <div class="fl ext"></div>

</div>

说明:

  1. 这样平台属性就拼接到url中,并且能保持参数了
  2. 点击平台属性,改平台属性就不在列表中显示了,控制如下:

th:unless="${#strings.contains(urlParam, 'props='+baseAttrInfo.attrId)}"

  1. 品牌显示
<div class="type-wrap logo" th:if="${searchParam.trademark == null}">

    <div class="fl key brand">品牌</div>

    <div class="value logos">

        <ul class="logo-list">

            <li th:each="trademark:${trademarkList}">

                <a href="" th:text="${trademark.tmName}">属性值</a>

            </li>

        </ul>

    </div>

</div>

说明:th:if="${searchParam.trademark == null}" 控制品牌是否显示

说明:目前页面已经渲染,但是搜索条件我们怎么处理,搜索条件值如何保持等问题还没解决,如图:

说明:所有的搜索条件都拼接到了一个url上面,除分页参数与排序

3、分页处理

<div class="sui-pagination pagination-large">

    <ul>

        <li class="prev" th:if="${pageNo != 1}">

            <a th:href="${urlParam}+'&pageNo='+${pageNo - 1}">上一页</a>

        </li>

        <li class="prev disabled" th:if="${pageNo == 1}">

            <a href="javascript:">上一页</a>

        </li>



        <li th:each="i : ${#numbers.sequence(1,totalPages)}" th:class="${i == pageNo} ? 'active' : ''">

            <a th:href="${urlParam}+'&pageNo='+${i}"><span th:text="${i}"></span></a>

        </li>



        <li class="next" th:if="${pageNo < totalPages}">

            <a th:href="${urlParam}+'&pageNo='+${pageNo + 1}">下一页</a>

        </li>

        <li class="next disabled" th:if="${pageNo == totalPages}">

            <a href="javascript:">下一页</a>

        </li>

    </ul>

    <div><span><span th:text="${totalPages }"></span>&nbsp;</span><span></div>

</div>  

(4)面包屑处理

ListController

 list接口:添加 

/**
 * 处理品牌条件回显
 * @param trademark
 * @return
 */
private String makeTrademark(String trademark) {
    if (!StringUtils.isEmpty(trademark)) {
        String[] split = StringUtils.split(trademark, ":");
        if (split != null && split.length == 2) {
            return "品牌:" + split[1];
        }
    }
    return "";
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/870608.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

手撕C++入门基础

1.C介绍 C课程包括&#xff1a;C语法、STL、高阶数据结构 C参考文档&#xff1a;Reference - C Reference C 参考手册 - cppreference.com cppreference.com C兼容之前学习的C语言 2.C的第一个程序 打印hello world #define _CRT_SECURE_NO_WARNINGS 1 // test.cpp // …

软件测试---接口测试

一、接口及接口测试概念 &#xff08;1&#xff09;接口的类型 &#xff08;2&#xff09;接口测试的概念 &#xff08;3&#xff09;接口测试的原理 &#xff08;4&#xff09;接口测试的特点 &#xff08;5&#xff09;接口测试的实现方式 二、HTTP协议 &#xff08;1&#…

C++:哈希

目录 unordered系列关联式容器 1&#xff1a;unordered_map And unordered_multimap 2&#xff1a;unordered_set And unordered_multiset 3&#xff1a;哈希冲突 4&#xff1a;哈希冲突 5&#xff1a;哈希函数 6&#xff1a;解决哈希冲突 1&#xff1a;闭散列 2&#xf…

Linux高编-进程的概念(1)

目录 1.ps aux 2.top 3.kill -2 进程pid // fork函数 getpid拿自己的进程号 getppid拿父进程号 fork&#xff08;&#xff09;&&fork&#xff08;&#xff09;||fork&#xff08;&#xff09; 父子进程的关系&#xff1a; 僵尸进程&#xff0c;孤儿进程 僵…

招生简章不会设计?这个网站可以供你参考

招生简章是学校与潜在学生之间的第一座桥梁&#xff0c;它的设计直接影响到学校的形象和招生效果。如果你在设计招生简章时感到困惑&#xff0c;不妨参考以下几个要点&#xff0c;让你的招生简章更加吸引人。 1.明确目标受众&#xff1a;在设计招生简章之前&#xff0c;首先要明…

Cesium模型制作,解决Cesium加载glb/GLTF显示太黑不在中心等问题

Cesium模型制作&#xff0c;解决Cesium加载glb/GLTF显示太黑不在中心等问题 QQ可以联系这里&#xff0c;谢谢

关于xilinx的FFTIP的使用和仿真

工具&#xff1a;vivado2018.3&#xff0c;modelsim10.6d 场景&#xff1a;在进行数据进行频谱分析的时候&#xff0c;使用FPGA来完成FFT的计算可以加快数据的计算速度。 下面使用仿真完成DDS产生的数据的FFT以及IFFT。原始数据使用DDSIP产生&#xff0c;通过IP产生的波形数据…

【Linux入门】Linux常见指令

目录 前言 一、Linux基本指令 1.ls指令 2.pwd命令 3.cd 指令 4.touch指令 5.mkdir指令 6.rmdir指令 && rm 指令 7.man指令 8.cp指令 9.mv指令 10.cat 11.date 12.top 13.shutdown-关机 14.重要的几个热键 二、Linux扩展指令 总结 前言 Linux指令是在…

map/set和unordered_map/unordered_set的区别及使用情况

map/set和unordered_map/unordered_set的区别 容器底层数据结构是否有序实现版本复杂度迭代器map/set红黑树有序C98O(logN&#xff09;双向迭代器unordered_map/unordered_set哈希表/散列表无序C11O(1)单向迭代器 unordered_set无序的&#xff08;VS下&#xff09; void uno…

Spring IoCDI(下)—DI的尾声

我们之前学习了控制反转IoC&#xff0c;接下来就开始学习依赖注入DI的细节。 依赖注入是一个过程&#xff0c;是指IoC容器在创建Bean时&#xff0c;去提供运行时所依赖的资源&#xff0c;而资源指的就是对象。我们使用 Autowired 注解&#xff0c;完成依赖注入的操作。简单来说…

【数据结构初阶】二叉树--基本概念

hello&#xff01; 目录 一、树 1.1 树的概念和结构 1.2 树的相关术语 1.3 树的表示 1.4 树形结构实际应用场景 二、二叉树 2.1 概念和结构 2.2 特殊的二叉树 2.2.1 满二叉树 2.2.2 完全二叉树 2.3 二叉树的存储结构 2.3.1 顺序结构 2.3.2 链式结构 …

keil调试程序进入“BEAB BKPT 0xAB“断点处

1&#xff1a;异常现象 发现程序新增加代码的时候&#xff0c;程序会进入 “BEAB BKPT 0xAB” 断点处&#xff0c;无法进入main函数&#xff1b; 2&#xff1a;异常原因 屏蔽新增加的代码&#xff0c;最后发现是复制过来的代码中有 printf() 函数打印日志&#xff0c;但是k…

Windows 环境下 Go 语言使用第三方压缩包 gozstd 的报错处理

该文章主要记录在windows平台用go语言使用gozstd包时&#xff0c;遇到的错误及处理过程&#xff08;踩坑之旅&#xff09;&#xff01; 一、gozstd简介 gozstd是一个针对Zstandard&#xff08;简称Zstd&#xff09;的Go语言包装器&#xff0c;它提供了简单且高效的API&#xf…

赋能基层,融合创新:EasyCVR视频汇聚平台构建平安城市视频共享系统

一、雪亮工程建设的意义 雪亮工程的核心在于通过高清视频监控、环境监测和智能预警等先进技术手段&#xff0c;构建一个高效、智能、安全、便捷的社会安全防控体系。这一工程的建设不仅代表了现代化科技手段在城市治安管理中的应用&#xff0c;更是提升社会安全保障能力、推动…

【Angular18】封装自定义组件

1. 准备组件 2. 创建打包文件夹及部分配置文件 创建 文件夹app-legalentities-root拷贝组件源文件到新的文件夹app-legalentities中创建文件 .npmrc registry发布地址always-authtrue创建文件 ng-package.json {"$schema": "./node_modules/ng-packagr/ng-pac…

自动化解决 reCAPTCHA v2:CapSolver 教程

对于那些经常进行网页爬取的人来说&#xff0c;你是否曾觉得 reCAPTCHA v2 就像是互联网版的过于严格的裁判员&#xff0c;总是在质疑你的真实性&#xff1f;但如果你能够轻松且合规地与这些裁判员达成和解&#xff0c;使你的网络搜索和自动化任务变得更顺畅&#xff0c;那该有…

社交媒体分析:如何利用Facebook的数据提升业务决

在数字化时代&#xff0c;社交媒体已经成为企业战略中不可或缺的一部分。Facebook&#xff0c;作为全球最大的社交平台之一&#xff0c;提供了丰富的数据资源&#xff0c;这些数据不仅能够帮助企业了解市场趋势&#xff0c;还能提升业务决策的精准度。本文将探讨如何有效利用Fa…

共享经济背景下校园、办公闲置物品交易平台-计算机毕设Java|springboot实战项目

&#x1f34a;作者&#xff1a;计算机毕设匠心工作室 &#x1f34a;简介&#xff1a;毕业后就一直专业从事计算机软件程序开发&#xff0c;至今也有8年工作经验。擅长Java、Python、微信小程序、安卓、大数据、PHP、.NET|C#、Golang等。 擅长&#xff1a;按照需求定制化开发项目…

navicate premium16破解

下载链接&#xff1a;https://pan.baidu.com/s/1BWowOJLYchFcRMgIn-j97A?pwdvmfu 双击安装navicat160_premium_cs_x64.exe&#xff0c;安装完不要打开 然后断网打开NavicatCracker.exe 打开如果报病毒按照下面方法处理&#xff1a; 记得一定要断网&#xff0c;不断网…

安卓相关环境配置

安卓相关环境配置 偶尔更新。。。 JEB&#xff08;动态调试好用&#xff09; JEB动态调试Smali-真机/模拟器&#xff08;详细&#xff0c;新手必看&#xff09; 夜步城 JADX官网&#xff08;静态分析&#xff09; https://github.com/skylot/jadx/releases/tag/v1.5.0 雷…