【PHP】购物车的加减算总额

简介: 【PHP】购物车的加减算总额

author:咔咔


wechat:fangkangfk


前端代码:


<if condition="!isset($_SESSION['Cart'][$k]['user_num'])">
  <div class="none hidebox num"  data-id="'+foodinfo[i].id+'">0</div>
  <div class="none hidebox reduce" style="cursor:pointer">-</div>
<else />
  <div class=" hidebox num"  data-id="'+foodinfo[i].id+'">{$_SESSION['Cart'][$k]['user_num']}
  </div>
  <div class=" hidebox reduce" style="cursor:pointer">-</div>
</if>
js:
//点击加
$(document).on('click','.add',function(){
    $(this).parent().find('.hidebox').show();
    // 当点击的时候给父级加一个class,在循环的时候判断是否有check
    $(this).parent().addClass('check');
    // 获取到框内的初始值
    var num = $(this).parent().find('.num').text()
    // 点击的时候每次加1
    var final = Number(num) +1;
    // 将加过的数据赋值给数量值
    var num = $(this).parent().find('.num').text(final)
    // 获取到商品的id
    var shop_id = $(this).parents('.right_total').attr('shop_id');
    // 计算总价
    $.post("{:U('addon/WeiuidDeit/Mobile/listTotal')}",{id:shop_id,user_num:final},function(data){
        // 总价
        // $('#allmoney').html(data['return_data'][0]);
        $('#allmoney').html(data['return_data'][0]);
        // 总数量
        $('#allcount').html(data['return_data'][1]);
    },'json')
})
//点击减
$(document).on('click','.reduce',function(){
    // 获取到input的初始值
    var num = $(this).parent().find('.num').text()
    // 点击一次减1
    var final = Number(num) - 1;
    // 数量框最终的值
    var num = $(this).parent().find('.num').text(final)
    // 获取到商品的id
    var shop_id = $(this).parents('.right_total').attr('shop_id');
    $.post("{:U('addon/WeiuidDeit/Mobile/listTotal')}",{id:shop_id,user_num:final},function(data){
        // 总价
        $('#allmoney').html(data['return_data'][0]);
        // 总数量
        $('#allcount').html(data['return_data'][1]);
    },'json')
    if(final<1 ){
        $(this).parent().find('.num').html(0);
        $(this).parent().find('.hidebox').hide();
    }
})


控制器:


这是没有经过封装的代码,参考后需要简单封装一下


/*
思路:
    前台点击加和减
    异步传输商品的数量和商品id
    根据商品id查询对应商品信息
    准备存根据商品信息存session
    点击加和减的时候判断session的下标(商品的id)是否存在
    当session下标id不存在则创建,保存商品的基本信息,
    并根据数量和单价计算单个商品的小计和,在购物车也可以使用
    当session下标id存在的时候,只需要修改对应商品的数量和总价
    在这里需要做个容错,当用户数量为小于等于0的时候,
    直接删除对应商品的session数据
    根据以上操作就来到了关键
    将所有商品的小计,数量的总和相加,重新赋值session
    视图的总数量和总价直接输出session的值即可
*/
  // 列表页左下角计算总价
  public function listTotal(){
      // 商品的数量和id 
      $shop_id = I();
      // 获取到用户数量
      $user_num = I('user_num',0);
      $cart= D('food');
      // session('Cart',null);
      // 查询购物车信息
      $cart_data = $cart->where([
        'id'=>$shop_id['id']
        ])->find();
      $shop_data = $cart->select();
      // 点加减号的时候判断session有无商品
      if(!isset($_SESSION['Cart'][$cart_data['id']])){
        // 如果session不存在商品id时创建session和数据库添加
        session('Cart.'.$cart_data['id'],[
          'id'=>$cart_data['id'],
          'user_num'=>$user_num,
          'goods_price'=>$cart_data['food_price'],
          'goods_name'=>$cart_data['food_name'],
          'total'=>$cart_data['food_price']*$user_num,
          'goods_picture' => $cart_data['food_picture'],
          'goods_name' => $cart_data['food_name']
          ]);
      }else{
          // 如果session存在商品id的话就修改
          $_SESSION['Cart'][$cart_data['id']]['user_num'] = $user_num;
          $_SESSION['Cart'][$cart_data['id']]['total'] = $cart_data['food_price']*$user_num;
          // 如果有商品并且减到不选择商品将session删除
          if($user_num <= 0){
            unset($_SESSION['Cart'][$cart_data['id']]);
          }
      }
      $cart_list = session('Cart');
      $total = 0;
      $num = 0;
      // 最终的商品信息session值
      foreach($cart_list as $k=>$v){
        // 计算总价
        $total += $v['total'];
        // 计算总数量
        $num += $v['user_num'];
      }
      session('total',$total);
      session('num',$num);
      $cartlist = array($total,$num);
      if(!$cartlist){
         $return['return_code'] = 400;
         $return['return_msg'] = '购物车空空如也';
      }else{
           $return['return_code'] = 200;
           $return['return_msg'] = '查询成功';
           $return['return_data'] = $cartlist;
      }
      $this->ajaxReturn($return);
  }


相关文章
|
7天前
|
安全 关系型数据库 MySQL
PHP与MySQL交互:从入门到实践
【9月更文挑战第20天】在数字时代的浪潮中,掌握PHP与MySQL的互动成为了开发动态网站和应用程序的关键。本文将通过简明的语言和实例,引导你理解PHP如何与MySQL数据库进行对话,开启你的编程之旅。我们将从连接数据库开始,逐步深入到执行查询、处理结果,以及应对常见的挑战。无论你是初学者还是希望提升技能的开发者,这篇文章都将为你提供实用的知识和技巧。让我们一起探索PHP与MySQL交互的世界,解锁数据的力量!
|
关系型数据库 MySQL PHP
PHP 原生操作 Mysql
PHP 原生操作 Mysql
111 0
|
18天前
|
NoSQL 关系型数据库 MySQL
不是 PHP 不行了,而是 MySQL 数据库扛不住啊
【9月更文挑战第8天】这段内容讨论了MySQL在某些场景下面临的挑战及其原因,并指出这些问题不能完全归咎于MySQL本身。高并发读写压力、数据量增长以及复杂查询和事务处理都可能导致性能瓶颈。然而,应用程序设计不合理、系统架构不佳以及其他数据库选择和优化策略不足也是重要因素。综合考虑这些方面才能有效解决性能问题,而MySQL通过不断改进和优化,仍然是许多应用场景中的可靠选择。
|
30天前
|
存储 SQL 关系型数据库
PHP与MySQL交互的奥秘
【8月更文挑战第29天】在编程的世界里,PHP和MySQL就像是一对默契的舞伴,共同演绎着数据的交响曲。本文将带你探索它们之间的互动,从连接数据库到执行查询,再到处理结果,每一步都充满了节奏与和谐。我们将一起走进这段代码的旅程,感受数据流动的魅力。
|
28天前
|
SQL 关系型数据库 MySQL
PHP与MySQL交互之基础教程
【8月更文挑战第31天】 在数字世界中,数据是推动一切的核心力量。本文将引导你探索PHP与MySQL的协同工作,通过实际代码示例,展示如何建立连接、执行查询以及处理结果集。无论你是初学者还是希望巩固知识的开发者,这篇文章都将为你提供宝贵的实践知识。
|
2月前
|
数据库
基于PHP+MYSQL开发制作的趣味测试网站源码
基于PHP+MYSQL开发制作的趣味测试网站源码。可在后台提前设置好缘分, 自己手动在数据库里修改数据,数据库里有就会优先查询数据库的信息, 没设置的话第一次查询缘分都是非常好的 95-99,第二次查就比较差 , 所以如果要你女朋友查询你的名字觉得很好 那就得是她第一反应是查和你的缘分, 如果查的是别人,那不好意思,第二个可能是你。
51 3
|
4月前
|
关系型数据库 MySQL PHP
|
3月前
|
NoSQL 关系型数据库 MySQL
linux服务器重启php,nginx,redis,mysql命令
linux服务器重启php,nginx,redis,mysql命令
61 1
|
3月前
|
Ubuntu 关系型数据库 MySQL
ubuntu apt 安装wordpress所需所有的 一键脚本 扩展您的PHP似乎没有安装运行WordPress所必需的MySQL扩展。
ubuntu apt 安装wordpress所需所有的 一键脚本 扩展您的PHP似乎没有安装运行WordPress所必需的MySQL扩展。
49 0
ubuntu apt 安装wordpress所需所有的 一键脚本 扩展您的PHP似乎没有安装运行WordPress所必需的MySQL扩展。
|
3月前
|
前端开发 关系型数据库 MySQL
使用 PHP 和 MySQL 实现留言板功能
使用 PHP 和 MySQL 实现留言板功能
105 0