91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Ajax 學習

發布時間:2020-07-30 06:24:08 來源:網絡 閱讀:643 作者:zy2015趙勇 欄目:開發技術




index.jsp頁面

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>

<!--
1.獲取當前頁面的所有的a節點,并為每一個a節點都添加onclick 響應函數,同時取消其默認行為
2.準備發送Ajax請求:url(a節點的href屬性值);args 時間戳
3.響應為一個JSON對象,包括:bookName totalBookNumber totalMoney
4.把對應的屬性添加到對應的位置

 -->
 <script type="text/javascript" src="${pageContext.request.contextPath }/script/jquery.js"></script>
 <script type="text/javascript">
 $(function(){
     var isHasCart = "${sessionScope.sc == null}";
     if(isHasCart == "true"){
         $("#status").hide();
     }else {
         $("#status").show();
         //這里的sc是ShoppingCart的對象他會去調用sc.屬性對應的get方法
         $("#bookName").text("${sessionScope.sc.bookName}");
         $("#totalNumber").text("${sessionScope.sc.totalNumber}");
         $("#totalMoney").text("${sessionScope.sc.totalMoney}");
     }
    
    $("a").click(function(){
        //顯示指定的選擇器
        $("#status").show();
        var url = this.href;
        var args = {"time":new Date()};
        $.getJSON(url, args, function(data){
            $("#bookName").text(data.bookName);
            $("#totalNumber").text(data.totalNumber);
            $("#totalMoney").text(data.totalMoney);
        });
        return false;
    });
 });
 
 </script>
 
</head>
<body>

    <div id="status">
        您已經將&nbsp;<span id="bookName"></span> &nbsp;
        加入到購物車,購物車中的書有&nbsp;<span id="totalNumber"></span> &nbsp;本,
        總價格&nbsp;<span id="totalMoney"></span> &nbsp;元。
        <br><br>
    </div>
    Java &nbsp; &nbsp; &nbsp; <a href="${pageContext.request.contextPath}/addToCart?id=Java&price=150">加入購物車</a>    
    <br><br>
    
    Oracle &nbsp; <a href="${pageContext.request.contextPath }/addToCart?id=Oracle&price=200">加入購物車</a>    
    <br><br>
    
    Struts2 &nbsp; <a href="${pageContext.request.contextPath }/addToCart?id=Struts2&price=100">加入購物車</a>    
    <br><br>
    
</body>
</html>

//SERVLET類

package com.ajax.app.servlet;

import java.io.IOException;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

import com.ajax.beans.ShoppingCart;
import com.fasterxml.jackson.databind.ObjectMapper;

@WebServlet("/addToCart")//這里這樣寫注解后就不用再web.xml中配置servlet了
public class AddToCartServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        this.doPost(request, response);
    }

    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //1.獲取請求參數:id , price
        
        String bookName = request.getParameter("id");
        int price = Integer.parseInt(request.getParameter("price"));
        
        //2.獲取購物車對象。
        HttpSession session = request.getSession();
        ShoppingCart sc = (ShoppingCart) session.getAttribute("sc");
        if(sc == null){
            sc = new ShoppingCart();
            session.setAttribute("sc", sc);
        }
        
        //3.把點擊的選項加入到購物車中
        sc.addToCart(bookName, price);
        
        //4.準備響應的JSON對象:{"bookName":"","totalNumber":1,"totalMoney":1}
        //這里的\"相當于一個'  但是這里不能寫'
    /*    StringBuilder result = new StringBuilder();
        result.append("{")
              .append("\"bookName\":\""+bookName+"\"")
              .append(",")
              .append("\"totalNumber\":"+sc.getTotalNumber())
              .append(",")
              .append("\"totalMoney\":"+sc.getTotalMoney())
              .append("}");
        
        response.setContentType("text/javascript");
        response.getWriter().print(result.toString());*/
        
        ObjectMapper mapper = new ObjectMapper();
        response.setContentType("text/javascript");
        System.out.println(mapper.writeValueAsString(sc));
        //響應ShoppingCart對象的JSON字符串
        response.getWriter().print(mapper.writeValueAsString(sc));
        
        
    }

}


//ShoppingCart類

package com.ajax.beans;

import java.util.HashMap;
import java.util.Map;

public class ShoppingCart {
    
    //存放shoppingcartItem 的鍵 書名:值
    private Map<String, ShoppingCartItem> items = new HashMap<>();
    
    private String bookName;
    
    
    public void addToCart(String bookName, int price){
        this.bookName = bookName;
        if(items.containsKey(bookName)){
            ShoppingCartItem item = items.get(bookName);
            item.setNumber(item.getNumber() + 1);
            item.setPrice(item.getPrice()+price);
        }else {
            ShoppingCartItem item = new ShoppingCartItem();
            item.setBookName(bookName);
            item.setPrice(price);
            item.setNumber(1);
            
            items.put(bookName, item);
        }
        
    }
    
    public int getTotalNumber(){
        int total = 0;
        for(ShoppingCartItem item: items.values()){
            total += item.getNumber();
        }
        return total;
    }
    
    
    public int getTotalMoney(){
        int money = 0;
        for(ShoppingCartItem item: items.values()){
            money +=  item.getPrice();
        }
        return money;
    }

    public String getBookName() {
        return bookName;
    }

}


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

五莲县| 固阳县| 双辽市| 镇康县| 华坪县| 鲁山县| 依安县| 财经| 阳新县| 台南县| 德保县| 静安区| 名山县| 通化市| 宁津县| 潼南县| 裕民县| 静乐县| 庆元县| 万州区| 都江堰市| 盐城市| 交城县| 昌黎县| 巴林右旗| 启东市| 上高县| 北安市| 樟树市| 大同县| 勐海县| 新邵县| 鞍山市| 肃宁县| 阿坝县| 诸城市| 九江县| 夏河县| 铁岭县| 宁远县| 武邑县|