【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);
  }


目录
打赏
0
0
0
0
14
分享
相关文章
PHP与MySQL交互:从入门到实践
【9月更文挑战第20天】在数字时代的浪潮中,掌握PHP与MySQL的互动成为了开发动态网站和应用程序的关键。本文将通过简明的语言和实例,引导你理解PHP如何与MySQL数据库进行对话,开启你的编程之旅。我们将从连接数据库开始,逐步深入到执行查询、处理结果,以及应对常见的挑战。无论你是初学者还是希望提升技能的开发者,这篇文章都将为你提供实用的知识和技巧。让我们一起探索PHP与MySQL交互的世界,解锁数据的力量!
如何排查和解决PHP连接数据库MYSQL失败写锁的问题
通过本文的介绍,您可以系统地了解如何排查和解决PHP连接MySQL数据库失败及写锁问题。通过检查配置、确保服务启动、调整防火墙设置和用户权限,以及识别和解决长时间运行的事务和死锁问题,可以有效地保障应用的稳定运行。
56 25
PHP与MySQL动态网站开发实战指南####
【10月更文挑战第21天】 本文将深入浅出地探讨如何使用PHP与MySQL构建一个动态网站,从环境搭建到项目部署,全程实战演示。无论你是编程新手还是希望巩固Web开发技能的老手,都能在这篇文章中找到实用的技巧和启发。我们将一起探索如何通过PHP处理用户请求,利用MySQL存储数据,并最终呈现动态内容给用户,打造属于自己的在线平台。 ####
121 0
不是 PHP 不行了,而是 MySQL 数据库扛不住啊
【9月更文挑战第8天】这段内容讨论了MySQL在某些场景下面临的挑战及其原因,并指出这些问题不能完全归咎于MySQL本身。高并发读写压力、数据量增长以及复杂查询和事务处理都可能导致性能瓶颈。然而,应用程序设计不合理、系统架构不佳以及其他数据库选择和优化策略不足也是重要因素。综合考虑这些方面才能有效解决性能问题,而MySQL通过不断改进和优化,仍然是许多应用场景中的可靠选择。
190 9
PHP与MySQL动态网站开发:从基础到实践####
本文将深入探讨PHP与MySQL的结合使用,展示如何构建一个动态网站。通过一系列实例和代码片段,我们将逐步了解数据库连接、数据操作、用户输入处理及安全防护等关键技术点。无论您是初学者还是有经验的开发者,都能从中获益匪浅。 ####
PHP与MySQL动态网站开发实战指南####
——深入探索LAMP栈下的高效数据交互与处理技巧 ####
PHP与MySQL动态网站开发实战指南####
深入探索PHP与MySQL的协同工作机制,本文旨在通过一系列实战案例,揭示构建高效、稳定且用户友好的动态网站的秘诀。从环境搭建到数据交互,再到最佳实践分享,本文为开发者提供了一条清晰的学习路径,助力其在LAMP(Linux, Apache, MySQL, PHP/Perl/Python)栈上实现技术飞跃。 ####
php实现一个简单的MySQL分页
通过本文的详细步骤和代码示例,我们实现了一个简单的PHP MySQL分页功能。主要步骤包括计算总记录数、设置分页参数、查询当前页的数据以及生成分页链接。这种分页方式适用于大多数Web应用,能够有效提升用户体验和页面响应速度。
75 4
PHP与MySQL的无缝集成:构建动态网站的艺术####
本文将深入探讨PHP与MySQL如何携手合作,为开发者提供一套强大的工具集,以构建高效、动态且用户友好的网站。不同于传统的摘要概述,本文将以一个生动的案例引入,逐步揭示两者结合的魅力所在,最终展示如何通过简单几步实现数据驱动的Web应用开发。 ####
PHP与MySQL的高效协同开发策略####
本文深入探讨了PHP与MySQL在Web开发中的协同工作机制,通过优化配置、最佳实践和高级技巧,展示了如何提升数据库交互性能,确保数据安全,并促进代码可维护性。我们将从环境搭建讲起,逐步深入到查询优化、事务管理、安全防护及性能调优等核心环节,为开发者提供一套实战驱动的解决方案框架。 ####

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等