zoukankan      html  css  js  c++  java
  • 购物车的原理及实现.(仿京东实现原理)

    今天来开始写一下关于购物车的东西, 这里首先抛出四个问题:

    1)用户没登陆用户名和密码,添加商品, 关闭浏览器再打开后 不登录用户名和密码 问:购物车商品还在吗? 

    2)用户登陆了用户名密码,添加商品,关闭浏览器再打开后 不登录用户名和密码 问:购物车商品还在吗?   

    3)用户登陆了用户名密码,添加商品, 关闭浏览器,然后再打开,登陆用户名和密码  问:购物车商品还在吗?

    4)用户登陆了用户名密码,添加商品, 关闭浏览器 外地老家打开浏览器  登陆用户名和密码 问:购物车商品还在吗?

    上面四个问题都是以京东为模板, 那么大家猜猜结果是什么呢?
    1)在
    2)不在了
    3)在
    4)在

    如果你能够猜到答案, 那么说明你真的很棒, 那么关于这四点是怎么实现的呢? (如果有不认可的小伙伴可以用京东实验一下)
    下面我们就来讲解下购物车的原理,最后再来说下具体的code实现.
    1)用户没有登录, 添加商品, 此时的商品是被添加到了浏览器的Cookie中, 所以当再次访问时(不登录),商品仍然在Cookie中, 所以购物车中的商品还是存在的.
    2)用户登录了,添加商品, 此时会将Cookie中和用户选择的商品都添加到购物车中, 然后删除Cookie中的商品. 所以当用户再次访问(不登录),此时Cookie中的购物车商品已经被删除了, 所以此时购物车中的商品不在了.
    3)用户登录, 添加商品,此时商品被添加到数据库做了持久化存储, 再次打开登录用户名和密码, 该用户选择的商品肯定还是存在的, 所以购物车中的商品还是存在的.
    4)理由3)


    这里再说下 没登录 保存商品到Cookie的优点以及保存到Session和数据库的对比:

    1:Cookie: 优点: 保存用户浏览器(不用浪费我们公司的服务器) 缺点:Cookie禁用,不提供保存
    2:Session:(Redis : 浪费大量服务器内存:实现、禁用Cookie) 速度很快
    3:数据库(Mysql、Redis、SOlr) 能持久化的就数据库 速度太慢

    那么我今天要讲的就是:

    用户没登陆:购物车添加到Cookie中
    用户登陆: 保存购物车到Redis中 (不用数据库)

    整体的思路图解:

  • 相关阅读:
    canvas---HTML5新特性
    flex布局之兼容
    前端Blob对二进制流数据的处理方式
    execCommand的复制
    express快速入门
    react+redux+webpack+git技术栈
    react开发
    gulp工程化工具
    python---django安装
    vue+webpack+element-ui+git
  • 原文地址:https://www.cnblogs.com/liliuguang/p/9591245.html
Copyright © 2011-2022 走看看