(自用)Java學習-5.15(模糊搜索,收藏,購物車)

1. 模糊搜索商品功能
  • 前端實現

    • 通過解析URL參數(如search=聯想)獲取搜索關鍵字,發送AJAX GET請求到后端接口/product/searchGoodsMessage

    • 動態渲染搜索結果:若結果非空,循環遍歷返回的商品數據,生成商品卡片(包含圖片、價格、標題),并綁定收藏和購物車功能按鈕;若結果為空,顯示“無商品信息”。

    • 使用replace()方法動態替換模板中的占位符(如#{id}#{price})。

  • 后端實現

    • 控制器接收關鍵字info,調用服務層執行模糊查詢。

    • SQL邏輯SELECT * FROM t_product WHERE title LIKE '%#{info}%' AND status=1 ORDER BY priority DESC LIMIT 0,12,限制返回前12條數據。

    • 返回JSON格式的商品列表數據。


2. 添加收藏功能
  • 前端實現

    • 點擊“加入收藏”按鈕觸發addFavoriteUse(pid)函數,彈出確認框后發送AJAX請求到/favorite/addFavoriteUse

    • 成功回調后更新按鈕狀態(如圖標變為“取消收藏”)。

  • 后端實現

    • 控制器從會話中獲取用戶ID和用戶名,調用服務層插入收藏記錄。

    • 服務層邏輯

      1. 根據商品ID查詢商品詳情(Product表)。

      2. 將商品信息(標題、價格、圖片)與用戶ID一起存入收藏表t_favorites

    • SQL邏輯INSERT INTO t_favorites插入完整收藏記錄,返回生成的自增收藏ID(fid)。


3. 添加購物車功能
  • 前端實現

    • 點擊“加入購物車”按鈕觸發addProToCart(id, price),發送POST請求到/cart/addProToCart,參數包含商品ID、價格和數量(默認1)。

    • 根據后端返回狀態碼彈出成功或失敗提示。

  • 后端實現

    • 核心邏輯

      1. 檢查當前用戶的購物車中是否已存在該商品。

      2. 若存在,更新商品數量(num = num + 1);若不存在,新增購物車記錄。

    • SQL邏輯

      • 查詢:SELECT * FROM t_cart WHERE pid=#{pid} AND uid=#{uid}

      • 插入:INSERT INTO t_cart記錄商品、用戶、數量、價格等信息。

      • 更新:UPDATE t_cart SET num=#{num}


4. 商品詳情展示
  • 前端實現

    • 從URL參數中提取商品ID(pid),請求接口/product/getProDetail獲取詳情數據。

    • 動態渲染商品標題、價格、庫存,并加載多張商品圖片(如1_big.png1.jpg)。

  • 后端實現

    • SQL邏輯SELECT * FROM t_product WHERE id=#{pid},直接返回商品完整信息。


5. 購物車展示
  • 前端實現

    • 請求接口/cart/showCartInfo獲取當前用戶的購物車列表數據。

    • 動態生成表格,展示商品圖片、標題、單價、數量(支持增減操作)、小計和刪除按鈕。

    • 使用模板替換占位符(如#{cid}#{image})填充數據。

  • 后端實現

    • SQL邏輯:聯表查詢t_cartt_product,返回視圖對象CartVo,包含購物車ID、商品信息、數量、小計等字段。

    • 查詢語句

      SELECT c.cid, c.pid, c.uid, c.num, p.price, p.image, p.title 
      FROM t_cart c LEFT JOIN t_product p ON c.pid = p.id 
      WHERE c.uid=#{uid} ORDER BY c.modified_time DESC;


6. 關鍵技術點
  1. 前后端交互

    • 使用AJAX異步請求,數據格式為JSON,通過RESTful風格接口通信。

  2. 數據庫操作

    • MyBatis實現SQL映射,動態拼接查詢條件(如模糊搜索LIKE)。

    • 聯表查詢優化數據展示(如購物車關聯商品表)。

  3. 功能擴展性

    • 分頁邏輯(LIMIT 0,12)支持后續擴展更多商品加載。

    • 收藏和購物車通過用戶會話(HttpSession)隔離不同用戶數據。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/82696.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/82696.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/82696.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

STM32 TIM 定時器深度剖析:結構、時基、中斷與應用開發(超形象詳解)

文章目錄 定時器(TIM)定時器種類與分布定時器的基本結構時基單元時基單元基本結構計數器計數方向時基單元時鐘來源計算寄存器預加載機制 自制延時函數獲取單片機當前時間實現延遲函數初始化定時器3的時基單元配置中斷編寫中斷響應函數測試延遲函數 定時器…

Java使用minio上傳整個目錄下的所有內容

目錄 1、添加相關配置 2、添加依賴 3、實現方法 1??基礎版: 2??優化版(推薦使用): 3??上傳遠程主機上的目錄內容: 4??直接上傳遠程主機中的目錄內容 業務背景:需要需要minio進行上傳指定目錄下所有…

Python的分布式網絡爬蟲系統實現

1. 系統架構概述 一個典型的分布式網絡爬蟲系統通常包含以下幾個核心組件: 1.主節點(Master Node): 任務調度:負責將抓取任務分配給各個工作節點。URL 管理:維護待抓取的 URL 隊列和已抓取的 URL 集合&a…

AI工具的選擇:Dify還是傳統工具?

從純技術視角出發,選擇Dify還是傳統開發工具需要基于六個核心維度進行理性決策。以下為結構化分析框架,附典型場景示例: 1. 開發效率 vs 控制力權衡矩陣 維度Dify優勢場景傳統工具優勢場景迭代速度需求明確的標準CRUD(如后臺管理…

2.3 TypeScript 非空斷言操作符(后綴 !)詳解

在 TypeScript 中,當你開啟了嚴格的空值檢查(strictNullChecks)后,變量如果可能是 null 或 undefined,就必須在使用前進行顯式的判斷。為了在某些場景下簡化代碼,TypeScript 提供了非空斷言操作符&#xff…

深度學習:損失函數與激活函數全解析

目錄 深度學習中常見的損失函數和激活函數詳解引言一、損失函數詳解1.1 損失函數的作用與分類1.2 回歸任務損失函數1.2.1 均方誤差(MSE)1.2.2 平均絕對誤差(MAE) 1.3 分類任務損失函數1.3.1 交叉熵損失(Cross-Entropy&…

掌握 npm 核心操作:從安裝到管理依賴的完整指南

圖為開發者正在終端操作npm命令,圖片來源:Unsplash 作為 Node.js 生態的基石,npm(Node Package Manager)是每位開發者必須精通的工具。每天有超過 1700 萬個項目通過 npm 共享代碼,其重要性不言而喻。本文…

Elasticsearch的運維

Elasticsearch 運維工作詳解:從基礎保障到性能優化 Elasticsearch(簡稱 ES)作為分布式搜索和分析引擎,其運維工作需要兼顧集群穩定性、性能效率及數據安全。以下從核心運維模塊展開說明,結合實踐場景提供可落地的方案…

國產三維CAD皇冠CAD(CrownCAD)建模教程:汽車電池

在線解讀『汽車電池』的三維建模流程,講解3D草圖、保存實體、拉伸凸臺/基體、設置外觀等操作技巧,一起和皇冠CAD(CrownCAD)學習制作步驟吧! 汽車電池(通常指鉛酸蓄電池或鋰離子電池)是車輛電氣系…

深入理解 JDK、JRE 和 JVM 的區別

在 Java 中,JDK、JRE 和 JVM 是非常重要的概念,它們各自扮演著不同的角色,卻又緊密相連。今天,就讓我們來詳細探討一下它們之間的區別。 一、JVM JVM 即 Java 虛擬機,它是整個 Java 技術體系的核心。JVM 提供了 Java…

云電腦顯卡性能終極對決:ToDesk云電腦/順網云/海馬云,誰才是4K游戲之王?

一、引言 1.1 云電腦的算力革命 云電腦與傳統PC的算力供給差異 傳統PC的算力構建依賴用戶一次性配置本地硬件,特別是CPU與顯卡(GPU)。而在高性能計算和游戲圖形渲染等任務中,GPU的能力往往成為決定體驗上限的核心因素。隨著游戲分…

撤銷Conda初始化

在安裝miniconda3的過程中,最后系統會出現這一行提示用戶可以選擇自動初始化,這樣的話,系統每次啟動就會自動啟動基礎(base)環境。 但是我們也可以通過 conda init --reverse $shell 來撤銷 Conda 的初始化設置。這將恢…

Flask-SQLAlchemy數據庫查詢:query

1、為什么可以用 模型類.query 來查詢數據庫? 在 Flask 中使用 SQLAlchemy ORM 時,所有繼承自 db.Model 的模型類都會自動獲得一個 query 屬性。 其本質是 db.session.query(模型類) 的快捷方式,無需顯式操作 db.session。 代碼示例&#…

【免費】【無需登錄/關注】度分秒轉換在線工具

UVE Toolbox 功能概述 這是一個用于地理坐標轉換的在線工具,支持兩種轉換模式: 十進制度 → 度分秒 度分秒 → 十進制度 使用方法 十進制度轉度分秒 在"經度"輸入框中輸入十進制度格式的經度值(例如:121.46694&am…

怎么判斷一個Android APP使用了React Native 這個跨端框架

要判斷一個 Android 應用是否使用了 React Native 框架,可以通過以下方法逐步驗證: 一、安裝包結構分析 1. 解壓 APK 將 .apk 文件重命名為 .zip 并解壓,檢查以下特征文件: ? assets/index.android.bundle: React Na…

Pluto實驗報告——基于2ASK的簡易的通信系統

一、實驗目的 1. 熟悉并掌握PLUTO SDR 主動學習模塊的使用; 2.通過matlab 編碼與adalm pluto 相配合達成一個簡易的通信系統,并能 夠傳輸一些較為簡單的信息。 二、實驗原理 2ASK 調制原理: 振幅鍵控是指利用載波的振幅變化來傳遞數字基帶信…

Ubuntu 24-部署FTP和自定義用戶

目錄 一、 安裝 vsftpd 二、創建 FTP 數據目錄 三、創建 FTP 用戶 四、配置 vsftpd 五、重啟 vsftpd 服務 六、增加新用戶腳本 一、 安裝 vsftpd sudo apt update sudo apt install vsftpd -y 二、創建 FTP 數據目錄 sudo mkdir -p /data/ftp sudo chown nobody:nogrou…

MySQL問題:什么是MySQL的中的最左匹配原則?

是指在復合索引中,查詢條件需要按照索引列的順序從最左側列開始依次匹配。只有查詢條件中的列按照索引的最左邊列開始進行匹配,索引才能被有效使用,但有時雖然不是正常順序,由于MySQL中存在優化器,會自動調整順序&…

2025軟考軟件設計師題目

選擇題(綜合題) 確定得分的 1、Linux外設目錄是什么 /dev。存儲磁盤的目錄 2、Linux外設sdc類型設備屬于什么 scsi hard disk。根據第一個字母s盲猜的 3、計算機中讓程序計數器PC不能指向當前運行程序的技術是 流水線。根據流水線的原理 4、Python程…

Deep Evidential Regression

摘要 翻譯: 確定性神經網絡(NNs)正日益部署在安全關鍵領域,其中校準良好、魯棒且高效的不確定性度量至關重要。本文提出一種新穎方法,用于訓練非貝葉斯神經網絡以同時估計連續目標值及其關聯證據,從而學習…