中文字幕在线一区二区在线,久久久精品免费观看国产,无码日日模日日碰夜夜爽,天堂av在线最新版在线,日韩美精品无码一本二本三本,麻豆精品三级国产国语,精品无码AⅤ片,国产区在线观看视频

      淺談Ajax修改購物車的方法

      時(shí)間:2024-06-29 15:14:52 AJAX 我要投稿
      • 相關(guān)推薦

      淺談Ajax修改購物車的方法

        今天由yjbys小編來給大家聊聊Ajax修改購物車的方法,希望對(duì)大家有所幫助。想了解更多相關(guān)資訊請(qǐng)持續(xù)關(guān)注我們應(yīng)屆畢業(yè)生培訓(xùn)網(wǎng)。

        1:購物車類的設(shè)計(jì)

        ShoppingCartItem:書的封裝,包括書名,數(shù)量,價(jià)格三個(gè)屬性,以及對(duì)應(yīng)的getter和setter方法。

        ShoppingCart:購物車封裝類,items為 Map<String, ShoppingCartItem> ,以及加入購物車,得到購物車中書的總數(shù)量以及總價(jià)格三個(gè)函數(shù)。

        2:jsp加入購物車,超鏈接中帶入書名以及價(jià)格

        <body>

        <!-- 加入span的目的是為了定位 -->

        <p id="cartstatus">

        您已經(jīng)將

        <span id="bookName"></span>加入到購物車中,購物車中有

        <span id="totalBookNumber"></span>本書,總價(jià)格是

        <span id="totalMoney"></span>

        </p>

        <br>

        <br>

        java

        <a

        href="${pageContext.request.contextPath}/addToCart?id=java&price=100">加入購物車</a>

        <br>

        ajax

        <a

        href="${pageContext.request.contextPath}/addToCart?id=ajax&price=200">加入購物車</a>

        <br>

        jquery

        <a

        href="${pageContext.request.contextPath}/addToCart?id=jquery&price=300">加入購物車</a>

        <br>

        </body>

        <!--${pageContext.request.contextPath}獲取該項(xiàng)目的絕對(duì)路徑 -->

        3:addToCart -----servlet的設(shè)計(jì)

        步驟如下:

        1) :獲取請(qǐng)求參數(shù) id(bookName),price,是從jsp頁面中的超鏈接來獲取的

        2):在session中獲取購物車對(duì)象,如果session屬性中沒有購物車,則新建一個(gè)購物車對(duì)象放置在session屬性中

        3) : 加入購物車操作Shopping.addToCart(bookName, price);

        4):想ajax傳遞Json對(duì)象,該對(duì)象包括 :{""bookName"":"totalBookNumber","totalMoney" },若從服務(wù)器端返回json對(duì)象,則屬性名必須使用雙引號(hào)!!

        5):響應(yīng)json請(qǐng)求,response.getWriter().print(json);

        public class AddToCartServlet extends HttpServlet {

        public void doGet(HttpServletRequest request, HttpServletResponse response)

        throws ServletException, IOException {

        this.doPost(request, response);

        }

        public void doPost(HttpServletRequest request, HttpServletResponse response)

        throws ServletException, IOException {

        //1:獲取請(qǐng)求參數(shù) id(bookName),price

        String bookName =request.getParameter("id");

        int price =Integer.parseInt(request.getParameter("price"));

        //2:獲取購物車對(duì)象,在session中

        ShoppingCart sc=(ShoppingCart) request.getSession().getAttribute("sc");

        if(sc==null){

        sc=new ShoppingCart();

        request.getSession().setAttribute("sc",sc);

        }

        //3;將點(diǎn)擊的對(duì)象加入到購物車中

        sc.addToCart(bookName, price);

        //4:準(zhǔn)備響應(yīng)的Json對(duì)象:{""bookName"":"totalBookNumber","totalMoney" }

        //若從服務(wù)器端返回json對(duì)象,則屬性名必須使用雙引號(hào)!!

        StringBuilder sBuilder=new StringBuilder();

        sBuilder.append("{")

        .append("\"bookName\":\""+bookName+"\"")

        .append(",")

        .append("\"totalBookNumber\":\""+sc.getTotalBookNumber()+"\"")

        .append(",")

        .append("\"totalMoney\":\""+sc.getTotalMoney()+"\"")

        .append("}");

        //響應(yīng)json請(qǐng)求

        response.setContentType("text/javascript");

        response.getWriter().print(sBuilder.toString());

        }

        }

        上述中的用StringBuilder來拼接JSON字符串的方式可以借助第三方開源Jackson來簡(jiǎn)化實(shí)現(xiàn):

        String jsonStr=null;

        ObjectMapper objectMapper=new ObjectMapper();

        jsonStr=objectMapper.writeValueAsString(sc);

        4:ajax接受從服務(wù)器傳來的參數(shù){""bookName"":"totalBookNumber","totalMoney" }

        步驟:

        1):為加入購物車這個(gè)超鏈接增加單擊響應(yīng)函數(shù),并取消默認(rèn)行為(return false)

        2):通過 HTTP GET 請(qǐng)求載入 JSON 數(shù)據(jù)。$.getJSON(url, [data], [callback])

        準(zhǔn)備url.agrs,并在回調(diào)函數(shù)內(nèi)部將購物車中的內(nèi)容顯示在Jsp頁面中。

        3):通過jquery中的hide(),show()方法,判斷是不是第一使用購物車,如果是第一次使用,則jsp頁面不顯示購物車。

        <head>

        <!--${pageContext.request.contextPath}獲取該項(xiàng)目的絕對(duì)路徑 -->

        <script type="text/javascript"

        src="${pageContext.request.contextPath}/scripts/jquery-1.7.2.js"></script>

        <script type="text/javascript">

        $(function(){

        var isHasCart="${sessionScope.sc==null}";

        if(isHasCart=="true"){

        $("#cartstatus").hide();//隱藏顯示的元素

        }else{

        $("#cartstatus").show(); //顯示隱藏的匹配元素

        $("#bookName").text("${sessionScope.sc.bookName}");

        $("#totalBookNumber").text("${sessionScope.sc.totalBookNumber}");

        $("#totalMoney").text("${sessionScope.sc.totalMoney}");

        }

        $("a").click(function(){

        $("#cartstatus").show();

        var url=this.href; //url屬性

        var agrs={"time":new Date()}; //時(shí)間戳

        $.getJSON(url,agrs,function(data){

        $("#bookName").text(data.bookName);

        $("#totalBookNumber").text(data.totalBookNumber);

        $("#totalMoney").text(data.totalMoney);

        });

        return false;

        });

        });

        </script>

        </head>

      【淺談Ajax修改購物車的方法】相關(guān)文章:

      使用ajax操作JavaScript對(duì)象的方法03-08

      公文的修改方法02-03

      基于ajax實(shí)現(xiàn)無刷新分頁的方法03-18

      淺談水星MW325R路由器密碼的修改方法03-16

      CAD修改線型的方法03-04

      CAD修改線顏色的方法03-04

      JS AJAX前臺(tái)如何給后臺(tái)類的函數(shù)傳遞參數(shù)的方法03-18

      CAD修改圖案填充的方法05-23

      手機(jī)修改ip地址方法03-08

      主站蜘蛛池模板: 昌江| 亚洲综合综合在线| 美女裸体无遮挡免费视频国产| 蜜桃av午夜福利一区二区三区| 靖西县| 放荡人妻一区二区三区| 国产9 9在线 | 免费| 蜜桃一区二区三区在线看| 国产尤物二区三区在线观看| 无遮挡很爽视频在线观看| 最新福利姬在线视频国产观看| 无码一区二区丝袜| 精品国产性色av网站| 国产chinese在线视频| 汨罗市| 富宁县| 鄢陵县| 景德镇市| 九江市| 舒兰市| 国产精品亚洲A∨无码遮挡| 朝阳县| 日韩人妻中文字幕一区二区| 国产尤物二区三区在线观看| 武邑县| 日韩av无卡无码午夜观看| 静海县| 国产精品成人无码久久久久久| 丰满人妻无套中出中文字幕| 亚洲成人av一区二区三区| 精品在免费线中文字幕久久| 午夜无码国产18禁| 蜜桃av无码免费看永久| a级日本理论片免费观看| 久久亚洲中文字幕视频| 国产精品久久久亚洲第一牛牛 | 亚洲精品AⅤ无码精品丝袜无码| 亚洲中文字幕av天堂| 韩国无码精品人妻一区二| 亚洲无码毛片免费视频在线观看| 一本大道久久精品一本大道久久 |