Javascript+ajax Shopping Cart Realization method

Source: Internet
Author: User

In order to save trouble, did not write their own JS Ajax use of jquery, of course, you can add to the jquery extension method, haha, I am too lazy, so write here.

The code is as follows Copy Code

var _$ = {ajax:function (urlparm, D, Beforecall, Successcall) {
$.ajax ({
URL: "Ashx/ajax_shoppingcart.ashx?" + Urlparm,
Data:d,
DataType: "Json",
Type: "POST",
Before:beforecall,
Success:successcall
});
}
};
(function () {
var jusoc = {};
JUSOC = {
_inital:function () {window. JUSOC = JUSOC; },
Base: {},
DAO: {},
BLL: {},
UI: {}
}
Jusoc.base = {
Validate: {
}
}
AJAX ()
Jusoc.dao = {
Shopping: {
Get:function (Beforecall, Successcall) {
_$. AJAX ("Action=get", NULL, Beforecall, Successcall);
},
Remove:function (PID, Beforecall, Successcall) {
_$. AJAX ("Action=remove", {"pid": pid}, Beforecall, Successcall);
},
Add:function (PID, Pcount, Beforecall, Successcall) {
_$. AJAX ("Action=add", {"pid": PID, "Pcount": Pcount}, Beforecall, Successcall);
},
Set:function (PID, Pcount, Beforecall, Successcall) {
_$. AJAX ("Action=set", {"pid": PID, "Pcount": Pcount}, Beforecall, Successcall);
}
}
}
JUSOC.BLL = {
Shopping: (function () {
var Data = null;
var islock = false;
var _successcall = null;
var _beforecall = null;
function Unlock () {
Islock = false;
}
function Lock () {
Islock = true;
if (Data&&data!=null)
{
Data = null;
}
}
function Callbackfunction (XHR) {
Unlock ();
if (xhr[0] = = "ERROR") {
Alert (xhr[1]);
Return
// }
else if (xhr[0] = = "SUCCESS") {
Jusoc.BLL.Shopping.SetData (xhr[1]);
// }
Jusoc.BLL.Shopping.SetData (XHR);
if (_successcall!= null && _successcall) {
_successcall.call (window, XHR);
}
_successcall = null;
}
function Preparerequst (Beforecall, Successcall) {
if (Islock) {
return false;
}
Lock ();
if (Beforecall!= null && beforecall) {
_beforecall = Beforecall;
}
if (Successcall!= null && successcall) {
_successcall = Successcall;
}
}
return {
Get:function (Beforecall, Successcall) {
if (Preparerequst (Beforecall, Successcall) ==false) return false;
Jusoc.DAO.Shopping.Get (_beforecall, callbackfunction);
},
Remove:function (PID, Beforecall, Successcall) {
if (Preparerequst (Beforecall, Successcall) ==false) return false;
Jusoc.DAO.Shopping.Remove (PID, _beforecall, callbackfunction);
},
Set:function (PID, Pcount, Beforecall, Successcall) {
if (Preparerequst (Beforecall, Successcall) ==false) return false;
Jusoc.DAO.Shopping.Set (PID, Pcount, Beforecall, callbackfunction);
},
Add:function (PID, Pcount, Beforecall, Successcall) {
if (Preparerequst (Beforecall, Successcall) ==false) return false;
JUSOC.DAO.SHOPPING.ADD (PID, Pcount, _beforecall, callbackfunction);
},
Getdata:function () {
alert (Data);
return Data;
},
Setdata:function (data) {data = data},
Removedata:function () {
if (data!= null && data)
Data= null;
}
}
})(),
XHR: {
}
}
Jusoc.ui = {
ShoppingCart: (function () {
function Constract () {
Jusoc.BLL.Shopping.Get (Null,setshoppingcart);
}
function Setshoppingcart (data) {
Here to populate the data in the shopping cart
var data = Jusoc.BLL.Shopping.GetData ();
This is where you build the entire shopping cart first.
var html = "<table class=" shoppingcart-list "id=" SM ">" +
"<tr>" +
"<th>" +
"Book ah" +
"</th>" +
"<th>" +
"title" +
"</th>" +
"<th>" +
"Unit Price" +
"</th>" +
"<th>" +
"Quantity" +
"</th>" +
"<th>" +
"Action" +
"</th>" +
"</tr>";
for (var i =0;i<data.length;i++)
{
html = "<tr>" +
"<td>" +
"<img src=" ss "height=" 36px "width=" 28px "/>" +
"</td>" +
"<td>" +
Data[i]. name+
"</td>" +
"<td>" +
"¥" +data[i]. money+
"</td>" +
"<td>" +
"<div class=" Item-change ">" +
"<input type=" text "Value= '" +data[i]. count+ "'/>" +
"<span title=" number plus one "class=" Add "onclick=" Jusoc.UI.ShoppingCart.Plus (1,this.parentnode.childnodes[0].value, This.parentnode.childnodes[0]) "></span> <span" +
"title=" number minus one "class=" Cut "onclick=" Jusoc.UI.ShoppingCart.Minus (1,this.parentnode.childnodes[0].value, This.parentnode.childnodes[0]) "></span>" +
"</div>" +
"</td>" +
"<td>" +
"<span class=" Removelink "onclick=" Jusoc.UI.ShoppingCart.Remove (1,this.parentnode.parentnode) ">remove from Cark</span> "+
"</td>" +
"</tr>";
}
html+= "</table>";
document.body.innerhtml+=html;
}
function Addtopanel (data) {
This is to add a product to the shopping cart to modify the foreground style
var obj = document.getElementById ("SM");
var html = "<td>" +
"<img src=" Soo "height=" 36px "width=" 28px "/>" +
"</td>" +
"<td>" +
Data. name+
"</td>" +
"<td>" +
"¥" +data. money+
"</td>" +
"&LT;TD >" +
"<div class=" Item-change ">" +
"<input type=" text "Value= '" +data. count+ "'/>" +
"<span title=" number plus one "class=" Add "onclick=" Jusoc.UI.ShoppingCart.Plus (1,this.parentnode.childnodes[0].value, This.parentnode.childnodes[0]) "></span> <span" +
"title=" number minus one "class=" Cut "onclick=" Jusoc.UI.ShoppingCart.Minus (1,this.parentnode.childnodes[0].value, This.parentnode.childnodes[0]) "></span>" +
"</div>" +
"</td>" +
"<td>" +
"<span class=" Removelink "onclick=" Jusoc.UI.ShoppingCart.Remove (1,this.parentnode.parentnode) ">remove from Cark</span> "+
"</td>";
var row = Obj.insertrow (1);
row.innerhtml = html;
Return
obj.childnodes[0].innerhtml + + html;
}
function UpdatePanel (obj, count) {
Here is the increase or decrease in the change operation from the shopping cart
Obj.value = count;
}
function Removefrompanel (Child)
{
var obj = document.getElementById ("SM");
Obj.childnodes[0].removechild (child);
}
return {
Pageload:function () {
Constract ();
},
Add:function (PID, Pcount) {
JUSOC.BLL.SHOPPING.ADD (Pid,pcount, NULL, Addtopanel);
},
Plus:function (PID, Pcount, obj) {
Pcount = parseint (pcount) + 1;
Jusoc.BLL.Shopping.Set (PID, Pcount, function () {alert ("before")}, function (data) {UpdatePanel (obj, Pcount)});
},
Minus:function (pid,pcount,obj) {
Pcount = parseint (pcount)-1;
Jusoc.BLL.Shopping.Set (pid,pcount,null,function (data) {UpdatePanel (Obj,pcount)});
},
Remove:function (pid,obj) {
Jusoc.BLL.Shopping.Remove (pid,null,function (data) {Removefrompanel (obj);});
}
}
})()
}
Jusoc._inital ();
})()

Instance


<! DOCTYPE HTML PUBLIC "-//W3C//DTD XHTML 1.0 transitional//en" "Http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd ">
<title></title>
<style type= "Text/css" >
*{margin:0; padding:0;border:0}
Body{font-size:. 85em;font-family:verdana,helvetica,simsun,arial, "Arial Unicode MS", Mingliu,pmingliu, "MS Gothic", Sans-serief;color: #232323; text-align:center; font-size:12px; Background-color: #fff;}
#ltRight {width:722px;float:left;position:relative;padding:16px 40px;text-align:left}
/*shoppingcart-list*/
. shoppingcart-list{border:1px solid #C2D8ED; Border-collapse:collapse;color: #666666; width:750px;}
. shoppingcart-list th{background-color: #F1F7F9; color: #666; font-size:13px;text-align:center;}
. shoppingcart-list tr{border:1px solid #C2D8ED; line-height:25px;text-align:center;}
. shoppingcart-list tr:hover{background-color: #fff;}
th, td{padding-left:5px;}
. item-change{font:12px/74px arial;text-align:center;width:58px;padding:28px 0 0 25px;height:46px;}
. item-change input{width:36px;height:19px;border:1px solid #C4C4C4; background:white;float:left;margin-top:1px; text-align:center;line-height:19px;margin-right:1px;font-size:12px;}
. Item-change span{width:17px;height:8px;float:left;display:block;margin-top:1px;font-size:0;line-height:0; border:1px solid #C9C9C9; text-indent: -9999px; Cursor:pointer}
. Item-change. Add{background:url (images/leftmenu/icon_cart.gif) no-repeat 6px-58px;
. Item-change. Cut{background:url (images/leftmenu/icon_cart.gif) no-repeat 6px-67px;
. Box_window {WIDTH:204PX;POSITION:ABSOLUTE;LEFT:-9999PX}
. Box_window. updatetip{width:184px;border:solid 1px #DFC9B2; Background-color: #FDF2E3; line-height:20px;padding: 11px 8px 8px;}
. t_c {Text-align:center}
. c_red_s {color: #C30; font-weight:bold;}
. Box_window. c_b {width:9px;height:6px;margin:0 auto;background:url (images/leftmenu/p_window_b.gif) no-repeat; Position:relative;margin-top: -1px;font-size:0;overflow:hidden;}
. removelink{Cursor:pointer}
</style>
<script src= ". /js/jquery-1.6.js "type=" Text/javascript "></script>
<script src= "Js/base. Jusoc.js "type=" Text/javascript "></script>
<script type= "Text/javascript" >
Window.onload =function () {
Jusoc.UI.ShoppingCart.PageLoad ();
}
</script>
<body>
<div id= "Ltright" >

Shopping Cart
<span style= "float:right; padding-right:20px; " > Total Amount: ¥<em id= "Cart-total" ></em></span>
<div id= "Update-message" style= "text-align:left; text-indent:48px; Font-weight:bold;
padding:6px; " >
</div>
<div id= "Item-tip" class= "Box_window" >
<div class= "Updatetip" >
<p class= "T_c" >
Modification Successful! </p>
<p>
The total amount of your merchandise is ¥<span class= "c_red_s" id= "Update_total_account" > @Model. Total.tostring ("0.00") </span> Meta </p >
<p class= "T_c" >
<a href= "javascript:void (0)" onclick= "$ (' #item-tip '). CSS (' left ', ' -9999px '); > Close </a></p>
</div>
<div class= "C_b" >
</div>
</div>
</div>
</body>

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.