學習筆記——CommonResult工具、書城項目第五階段(清空購物車、刪除購物項、對數量的修改)

来源:https://www.cnblogs.com/isDaHua/archive/2023/01/05/17027819.html
-Advertisement-
Play Games

2023-01-05 一、CommonResult工具 1、CommonResult工具的目的是:為了方便團隊開發。一般是在使用非同步的時候使用。 2、CommonResult工具的使用: (1)前端發送非同步請求到servlet。 (2)servlet給響應數據的時候,將所有數據都封裝到CommonR ...


2023-01-05

一、CommonResult工具

1、CommonResult工具的目的是:為了方便團隊開發。一般是在使用非同步的時候使用。

2、CommonResult工具的使用:

  (1)前端發送非同步請求到servlet。

  (2)servlet給響應數據的時候,將所有數據都封裝到CommonResult對象內。

二、清空購物車

2.1 找到清空購物車的超鏈接

      (1)cart.html中的第67行

<a href="cart?flag=clearCart" class="clear-cart">清空購物車</a>

  (2)在"CartServlet"中新建一個方法

protected void clearCart(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        request.getSession().removeAttribute("cart");
        //將頁面跳轉設置到cart.html
        this.processTemplate("cart/cart",request,response);
    }

  (3)在cart.html中的第52行中添加

<tbody v-if="totalCount==0">
          <tr>
            <td colspan="6" align="center">購物車為空,請點擊繼續購物</td>
          </tr>
 </tbody>

三、刪除購物項

3.1 找到刪除的超鏈接

  (1)找到“cart.html”中的第65行,使用“非同步”方式(綁定一個函數)

<td><a href="" @click="deleteCartItem">刪除</a></td>

  (2)在Vue中觸發一個函數,“cart.html”中的第167行

deleteCartItem:function(){
    //發佈非同步請求刪除當前購物項(將圖書的id帶過去)
    axios({
         method:"post",
         url:"cart",
         params:{
            flag:"deleteCartItem",
         }
    });
    event.preventDefault();//阻止控制項的預設行為
}            

  (3)在超鏈接上綁定一個"name"屬性

<td><a href="" @click="deleteCartItem" :name="cartItem.book.bookId">刪除</a></td>

  (4)獲取“name”屬性的值,在"cart.html"中的第169行

var id=event.target.name;

  (5)將id傳到“params”中

  (6)在"CartServlet"中設置一個方法

protected void deleteCartItem(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //1.獲得請求參數
        String id = request.getParameter("id");
        //2.獲得購物車對象
        HttpSession session = request.getSession();
        Cart cart = (Cart)session.getAttribute("cart");
        //3.調用cart中的方法刪除購物項
        
    }

  (7)到"Cart.java"中寫一個“刪除的方法”

  /**
     * 功能:刪除購物項
     * @param id
     */
    public void deleteCartItem(Integer id){
        map.remove(id);
    }

  (8)接著寫剛纔的方法

protected void deleteCartItem(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //1.獲得請求參數
        String id = request.getParameter("id");
        //2.獲得購物車對象
        HttpSession session = request.getSession();
        Cart cart = (Cart)session.getAttribute("cart");
        //3.調用cart中的方法刪除購物項
        cart.deleteCartItem(Integer.parseInt(id));
        //4.後臺的數據刪除成功了,但是前臺不刷新。因為是非同步請求
        showCart(request,response);
    }

  (9)轉到剛纔的“cart.html”中

deleteCartItem:function(){
    //發佈非同步請求刪除當前購物項(將圖書的id帶過去)
    axios({
         method:"post",
         url:"cart",
         params:{
            flag:"deleteCartItem",
         }
    }).then(response=>{
         if(response.data.flag){
                //需要將後臺傳過來的數據,展示在網頁上(Vue的方式)
                this.cartItems=response.data.resultData[0];
                this.totalCount=response.data.reultData[1];
                this.totalAmount=response.data.resultData[2];   
        }
    });
    event.preventDefault();//阻止控制項的預設行為
}     

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 2023-01-04 最近想用Cesium給學校做一個類似智慧校園的東西,要做的東西很多,首先是獲取學校模型的問題,然後怎麼用Cesium載入3Dtile 1.獲取學校模型 想到之前被老師抓苦力去做春熙路的圖,於是決定用比較熟悉的OSM數據集 https://www.openstreetmap.or ...
  • 本文簡介 點贊 + 關註 + 收藏 = 學會了 記錄一個在使用 HBuilderX 開發 App 時遇到的問題。 同步資源失敗,未得到同步資源的授權,請停止運行後重新運行,並註意手機上的授權提示 出現這個問題的原因是我把手機的 HBuilder App 給刪掉了,通過電腦連接數據線的方式安裝就會提示 ...
  • 小程式≠微信小程式 說到小程式,大部分同學的第一反應,可能是微信小程式、支付寶小程式,確實,小程式的概念深入人心,並且已經被約定俗成的綁定到某些互聯網公司的 APP 上。 但是,“小程式”並不是一個註冊商標,也不是哪一家的專利。 小程式作為一種人機交互的軟體載體、一種數字內容格式、一種代碼分發傳播機 ...
  • Scanner的幾個常用next輸入方法要點 1. next(): 一直接收從鍵盤中打入的內容直到讀取到回車,==此回車並不會被讀取==,且一定要讀取到有效字元後才可以結束輸入。 對輸入有效字元之前遇到的空格鍵、Tab鍵或Enter鍵等結束符,next()方法會自動將其去掉,只有在輸入有效字元之後, ...
  • .gitignore文件配置 .gitignore 文件可以用來忽略被指定的文件或文件夾的改動。記錄在.gitignore文件里的文件或文件夾是不會被 git 跟蹤到,也就是被忽略的文件是不會被上傳到遠程倉庫的,如果文件已經存在於遠程倉庫中就無法通過.gitignore文件來忽略。 下麵總結了一些可 ...
  • 由char和byte的關係引申出去——總結一下java中的字元編碼相關知識 一、字元編碼 手持兩把錕斤拷,口中直呼燙燙燙 ​ 在文章伊始,先來複習一下電腦中關於編碼的一些基礎知識,著重理清以下幾個基本概念。 1. 碼點(code point) ​ 電腦只能以二進位的形式存儲文字,故而電腦中每一 ...
  • 2023-01-05 一、設置購物項加號 (1)找到“+”號的位置,在“cart.html”中的第61行中,添加單擊事件,通過“非同步”操作來設置 <span class="count" @click="addCount">+</span> (2)在Vue中新建一個函數 addCount:functi ...
  • 題目鏈接 可以通過參考一道例題來加深對dfs的認知和學習 題意描述 按照字典序輸出自然數 1 到 n 所有不重覆的排列,即 n 的全排列,要求所產生的任一數 字序列中不允許出現重覆的數字。 輸出格式 由 1 ∼ n 組成的所有不重覆的數字序列,每行一個序列。每個數字保留 5 個場寬。 數據範圍 :1 ...
一周排行
    -Advertisement-
    Play Games
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...