免费观看又色又爽又黄的小说免费_美女福利视频国产片_亚洲欧美精品_美国一级大黄大色毛片

js如何實現購物車功能

這篇文章主要介紹了js如何實現購物車功能,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

做網站、成都網站建設過程中,需要針對客戶的行業特點、產品特性、目標受眾和市場情況進行定位分析,以確定網站的風格、色彩、版式、交互等方面的設計方向。成都創新互聯公司還需要根據客戶的需求進行功能模塊的開發和設計,包括內容管理、前臺展示、用戶權限管理、數據統計和安全保護等功能。

JS是什么

JS是JavaScript的簡稱,它是一種直譯式的腳本語言,其解釋器被稱為JavaScript引擎,是瀏覽器的一部分,主要用于web的開發,可以給網站添加各種各樣的動態效果,讓網頁更加美觀。

購物車實現3種方式

1、利用cookie

優點:不占用服務器資源,可以永遠保存,不用考慮失效的問題
缺點: 對購買商品的數量是有限制的,存放數據的大小 不可以超過2k,用戶如果禁用cookie那么就木有辦法購買商品,卓越網實現了用戶當用戶禁用cookie,也可以購買。

2、利用 session

優點:用戶禁用cookie,也可以購物
缺點:占用服務器資源,要考慮session失效的問題

3、利用數據庫

優點:可以記錄用戶的購買行為,便于數據分析用戶的喜好,推薦商品
缺點:給數據庫造成太大的壓力,如果數據量很大的話。

購物車需求分析

1、可以添加商品到購物車中

2、可以刪除購物車中的商品

3、可以清空購物車

4、可以更新購物車的商品

5、可以結算

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 商品的數量
 */
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, //是否打印調試信息
    'decimal' : decimal, //錢的精確到小數點后的位數
    'callback' : undefined
  };


  //暴露給外部的接口方法
  return {
    inited : false,
    init: function(option){
      //判斷用戶是否禁用cookie
      if(!window.navigator.cookieEnabled ){
        alert('您的瀏覽器不支持cookie無法使用購物車!,請設置允許設置cookie。');
        return false;
      }
      //從cookie中獲取購物車中的數據
      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){//根據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的數組下標
      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('商品已經存在了');
          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){ //更新商品的數量
      //更新一個商品
      var index = this.getItemIndex(item.sku);
      if(index > -1){
        items[index].quantity = item.quantity;
        _saveCookie();
      }else{
        if(options.debug){
          _log('商品不存在');
          return false;
        }
      }
    },
    emptyCart: function(){
      //清空數組
      items.length = 0;
      _saveCookie();
    },
    checkout: function(){
      //點擊結算后的回調函數
      if(options.callback){
        options.callback();
      }
    },
    getTotalCount: function(sku){
      //獲取購物車商品的數量,如果傳某個商品的id,那么就返回該商品的數量
      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});
    }

  };

  //***********************工具方法********************/
  //顯示調試信息
  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頁面簡單調用

<!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); //添加商品到購物車,參數item
    shopCart.delItem('12345'); //從購物車中刪除商品,參數squ
//    shopCart.emptyCart(); //清空購物車
    item.quantity = 4;
    alert(shopCart.getTotalPrice()); //獲取購物車中的數量,參數squ


    shopCart.findItem();//根據sku標示查找商品,參數squ
      //如果木有提供sku,則返回所有的item
    shopCart.getItemIndex('aa') //獲取item在items的數組下標,參數squ
    shopCart.updateQuantity(a) //更新商品的數量,參數item
    shopCart.getTotalCount()//獲取購物車商品的數量,如果傳某個商品的id,那么就返回該商品的數量,參數squ
  </script>

</body>
</html>

感謝你能夠認真閱讀完這篇文章,希望小編分享的“js如何實現購物車功能”這篇文章對大家有幫助,同時也希望大家多多支持創新互聯,關注創新互聯行業資訊頻道,更多相關知識等著你來學習!

當前題目:js如何實現購物車功能
分享鏈接:http://m.newbst.com/article44/gdioee.html

成都網站建設公司_創新互聯,為您提供品牌網站建設全網營銷推廣網站制作做網站網站改版網站設計

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

手機網站建設