js實現(xiàn)購物車功能
本文實例為大家分享了js實現(xiàn)購物車功能的具體代碼,供大家參考,具體內(nèi)容如下
購物車實現(xiàn)3種方式
1、利用cookie
優(yōu)點:不占用服務器資源,可以永遠保存,不用考慮失效的問題
缺點: 對購買商品的數(shù)量是有限制的,存放數(shù)據(jù)的大小 不可以超過2k,用戶如果禁用cookie那么就木有辦法購買商品,卓越網(wǎng)實現(xiàn)了用戶當用戶禁用cookie,也可以購買。
2、利用 session
優(yōu)點:用戶禁用cookie,也可以購物
缺點:占用服務器資源,要考慮session失效的問題
3、利用數(shù)據(jù)庫
優(yōu)點:可以記錄用戶的購買行為,便于數(shù)據(jù)分析用戶的喜好,推薦商品
缺點:給數(shù)據(jù)庫造成太大的壓力,如果數(shù)據(jù)量很大的話。
購物車需求分析
1、可以添加商品到購物車中
2、可以刪除購物車中的商品
3、可以清空購物車
4、可以更新購物車的商品
5、可以結(jié)算
js代碼
/**
* Created by Administrator on 2017/9/3.
*/
/***
* 購物車操作模塊
*
*/
//商品類
/***
* @name item
* @example
item(sku, name, price, quantity)
* @params {string} sku 商品的標示
* @params {string} name 商品的名字
* @param {number} price 商品的價格
* @param {number} quantity 商品的數(shù)量
*/
function item(sku, name, price, quantity){
this.sku = sku;
this.name = name;
this.price = price;
this.quantity = quantity;
}
var shopCart = function(window){
"use strict";
//全局變量
// note new new Date("2020-12-23") 在ie下面報錯,不支持這樣的語法
var items = [],cartName='kuaidian_shop_cart',expires = new Date( new Date().getTime()+86400000*30 )
,debug = true,decimal = 2;
var options = {
'cartName' : cartName, //cookie的名字
'expires' : expires, //cookie失效的時間
'debug' : debug, //是否打印調(diào)試信息
'decimal' : decimal, //錢的精確到小數(shù)點后的位數(shù)
'callback' : undefined
};
//暴露給外部的接口方法
return {
inited : false,
init: function(option){
//判斷用戶是否禁用cookie
if(!window.navigator.cookieEnabled ){
alert('您的瀏覽器不支持cookie無法使用購物車!,請設置允許設置cookie。');
return false;
}
//從cookie中獲取購物車中的數(shù)據(jù)
this.inited = true;
if(option){
extend(options,option);
}
var cookie = getCookie(options.cartName);
if(typeof cookie === 'undefined'){
setCookie(options.cartName,'',options.expires);
}else{
//每個item之間用&分開,item的屬性之間用|分割
var cookie = getCookie(options.cartName);
if(cookie){
var cItems = cookie.split('&');
for(var i=0,l=cItems.length;i<l;i++){
var cItem = cItems[i].split('|');
var item = {};
item.sku = cItem[0] || '';
item.name = cItem[1] || '';
item.price = cItem[2] || '';
item.quantity = cItem[3] || '';
items.push(item);
};
};
};
},
findItem: function(sku){//根據(jù)sku標示查找商品
//如果木有提供sku,則返回所有的item
if(sku){
for(var i=0,l=items.length;i<l;i++){
var item = items[i];
if(item.sku === sku){
return item;
}
}
return undefined;
}else{
return items;
}
},
getItemIndex : function(sku){ //獲取item在items的數(shù)組下標
for(var i=0,l=items.length;i<l;i++){
var item = items[i];
if(item.sku == sku){
return i;
}
}
//木有找到返回-1
return -1;
},
addItem: function(item){ //增加一個新商品到購物車
//添加一個商品
if(this.findItem(item.sku)){
if(options.debug){
_log('商品已經(jīng)存在了');
return false;
}
}
items.push(item);
_saveCookie();
return true;
},
delItem: function(sku){ //從購物車中刪除一個商品
//刪除一個商品
var index = this.getItemIndex(sku);
if(index > -1){
items.splice(index,1);
_saveCookie();
}else{
if(options.debug){
_log('商品不存在');
return false;
}
}
},
updateQuantity: function(item){ //更新商品的數(shù)量
//更新一個商品
var index = this.getItemIndex(item.sku);
if(index > -1){
items[index].quantity = item.quantity;
_saveCookie();
}else{
if(options.debug){
_log('商品不存在');
return false;
}
}
},
emptyCart: function(){
//清空數(shù)組
items.length = 0;
_saveCookie();
},
checkout: function(){
//點擊結(jié)算后的回調(diào)函數(shù)
if(options.callback){
options.callback();
}
},
getTotalCount: function(sku){
//獲取購物車商品的數(shù)量,如果傳某個商品的id,那么就返回該商品的數(shù)量
var totalCount = 0;
if(sku){
totalCount = (typeof this.findItem(sku) === 'undefined' ? 0 : this.findItem(sku).quantity );
}else{
for(var i=0,l=items.length;i<l;i++){
totalCount += (parseInt(items[i].quantity) === 'NaN' ? 0 : parseInt(items[i].quantity )) ;
}
}
return totalCount;
},
getTotalPrice : function(sku){
//獲取購物車商品的總價格 ,如果傳某個商品的id,那么就返回該商品的總價格
var totalPrice = 0.0;
if(sku){
var num = parseInt((typeof this.findItem(sku) === 'undefined' ? 0 : this.findItem(sku).quantity )),
price = parseFloat((typeof this.findItem(sku) === 'undefined' ? 0 : this.findItem(sku).price ));
num = num=== 'NaN' ? 0 : num;
price = price === 'NaN' ? 0 : price;
totalPrice = price * num;
}else{
for(var i=0,l=items.length;i<l;i++){
totalPrice += (parseFloat(items[i].price ) * parseInt(items[i].quantity));
}
}
return totalPrice.toFixed(options.decimal);
},
getCookie : getCookie,
setCookie : setCookie
};
/**
* 設置cookie
* @name setCookie
* @example
setCookie(name, value[, options])
* @params {string} name 需要設置Cookie的鍵名
* @params {string} value 需要設置Cookie的值
* @params {string} [path] cookie路徑
* @params {Date} [expires] cookie過期時間
*/
function setCookie(name, value, options) {
options = options || {};
var expires = options.expires || null;
var path = options.path || "/";
var domain = options.domain || document.domain;
var secure = options.secure || null;
/**
document.cookie = name + "=" + escape(value)
+ ((expires) ? "; expires=" + expires.toGMTString() : "")
+ "; path=" + path
+ "; domain=" + domain ;
+ ((secure) ? "; secure" : "");
*/
var str = name + "=" + encodeURIComponent(value)
+ ((expires) ? "; expires=" + expires.toGMTString() : "")
+ "; path=/";
document.cookie = str;
};
/**
* 獲取cookie的值
* @name getCookie
* @example
getCookie(name)
* @param {string} name 需要獲取Cookie的鍵名
* @return {string|null} 獲取的Cookie值,獲取不到時返回null
*/
function getCookie(name) {
var arr = document.cookie.match(new RegExp("(^| )" + name
+ "=([^;]*)(;|$)"));
if (arr != null) {
return decodeURIComponent(arr[2]);
}
return undefined;
};
//***********************私有方法********************/
function _saveCookie(){
var i=0,l=items.length;
if(l>0){
var tItems = [];
for(;i<l;i++){
var item = items[i];
tItems[i] = item.sku + '|' +item.name + '|' + item.price + '|' + item.quantity;
};
var str = tItems.join('&');
setCookie(options.cartName, str, {expires:options.expires});
}else{
setCookie(options.cartName, '', {expires:options.expires});
}
};
//***********************工具方法********************/
//顯示調(diào)試信息
function _log(info){
if(typeof console != 'undefined'){
console.log(info);
}
};
//繼承屬性
function extend(destination, source) {
for ( var property in source) {
destination[property] = source[property];
}
};
}(typeof window === 'undifined' ? this: window);
HTML頁面簡單調(diào)用
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<script type="text/javascript" src="./shop.js"></script>
<script>
shopCart.init({
'decimal' : 4
});
var a = new item('aa','bb',12,22);
shopCart.addItem(a); //添加商品到購物車,參數(shù)item
shopCart.delItem('12345'); //從購物車中刪除商品,參數(shù)squ
// shopCart.emptyCart(); //清空購物車
item.quantity = 4;
alert(shopCart.getTotalPrice()); //獲取購物車中的數(shù)量,參數(shù)squ
shopCart.findItem();//根據(jù)sku標示查找商品,參數(shù)squ
//如果木有提供sku,則返回所有的item
shopCart.getItemIndex('aa') //獲取item在items的數(shù)組下標,參數(shù)squ
shopCart.updateQuantity(a) //更新商品的數(shù)量,參數(shù)item
shopCart.getTotalCount()//獲取購物車商品的數(shù)量,如果傳某個商品的id,那么就返回該商品的數(shù)量,參數(shù)squ
</script>
</body>
</html>
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript Base64 作為文件上傳的實例代碼解析
這篇文章主要介紹了JavaScript Base64 作為文件上傳的實例代碼解析,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-02-02
JS導入本地json文件數(shù)據(jù)的三類方法舉例講解
作為一名剛?cè)胄械拈_發(fā)者,你可能會遇到需要在JavaScript中引用JSON文件的情況,下面這篇文章主要給大家介紹了關(guān)于JS導入本地json文件數(shù)據(jù)的三類方法,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2024-09-09
一文徹底講通JavaScript普通函數(shù)與箭頭函數(shù)的區(qū)別
JavaScript中的箭頭函數(shù)和普通函數(shù)在語法和特性上有一些關(guān)鍵的區(qū)別,這篇文章主要介紹了JavaScript普通函數(shù)與箭頭函數(shù)區(qū)別的相關(guān)資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2025-10-10
Javascript(es2016) import和require用法和區(qū)別詳解
本篇文章主要介紹了Javascript(es2016) import和require用法和區(qū)別詳解,具有一定的參考價值,有興趣的可以了解下2017-08-08
window resize和scroll事件的基本優(yōu)化思路
在項目中使用scroll事件去加載數(shù)據(jù),結(jié)果IE下悲劇了。下面為大家介紹下window resize和scroll事件的基本優(yōu)化思路,需要的朋友可以參考下2014-04-04

