通过AJAX方式动态更新ecshop购物车页面的商品数量

郑重承诺丨优站网提供安全交易、信息保真!
增值服务:
自动发货
网盘下载
安装指导
环境配置
二次开发
网站建设
¥ 0 (VIP免费升级VIP开通VIP尊享优惠特权
立即下载 升级会员 购买教程 售后支持
详情介绍

每次用户进入ecshop购物流程当需要更改购物车的数量必须手动点击更新按钮,这是非常糟糕的用户体验,我们有必要去改善它。
下面是通过AJAX动态更新ECShop购物车页面数量的解决方案

  • 一、前端页面部分(flow.dwt)
  • 在商品数量的input框添加对应的js函数
  • <INPUT  onblur=”changePrice(document.getElementById(‘goods_number_{$goods.rec_id}’).value,{$goods.rec_id})” name=”goods_number[{$goods.rec_id}]” id=”goods_number_{$goods.rec_id}” value=”{$goods.goods_number}”  id=”ECS_FORMBUY”>
  • 在文件最后添加一段js
  • <script type=”text/javascript”>
  • function changePrice(number,rec_id)
  • {
  •   var attr = getSelectedAttributes(document.forms[‘ECS_FORMBUY’]);
  •   var qty = document.forms[‘ECS_FORMBUY’].elements[‘number’].value;
  •    Ajax.call(‘flow.php’, ‘step=update_group_cart&rec_id=’ + rec_id +’&number=’ + number, changePriceResponse, ‘GET’, ‘JSON’);
  • }
  • function changePriceResponse(res)
  • {
  •   if (res.error > 0)
  •   {
  •     document.getElementById(‘sysmsg_error’).innerHTML = res.content;
  •     document.all.sysmsg_error.style.display=”;
  •   }
  •   else
  •   {
  •     if(document.all.sysmsg_error.style.display==”)
  •   {
  •    document.all.sysmsg_error.style.display=’none’;
  •   }
  •  document.getElementById(‘subtotal_’+res.rec_id).innerHTML = res.subtotal;
  •  document.getElementById(‘cart_amount’).innerHTML = res.cart_amount;
  •   }
  • }
  • </script>
  • 二、在flow.php文件中插入对应的处理代码:
  • elseif($_REQUEST[‘step’] == ‘update_group_cart’)
  • {
  • include_once(‘includes/cls_json.php’);
  • $json = new JSON();
  • $result = array(‘error’ => ”, ‘content’ => ”);
  • $rec_id = $_GET[‘rec_id’];
  • $number = $_GET[‘number’];
  • $group_buy = group_buy_info($_SESSION[‘extension_id’], $number);
  • if(!is_numeric($number))
  • {
  • $result[‘error’] = ’1′;
  • $result[‘content’] =’请输入合法数量’;
  • die($json->encode($result));
  • }
  • if ($group_buy[‘restrict_amount’] > 0 && $number > ($group_buy[‘restrict_amount’] – $group_buy[‘valid_goods’]))
  •  {
  • $result[‘error’] = ’1′;
  • $restrict_amount =  $group_buy[‘restrict_amount’] – $group_buy[‘valid_goods’];
  • $result[‘content’] =’您最多可买’.$restrict_amount.’件’;
  • die($json->encode($result));
  • }
  • $sql = “UPDATE ” . $GLOBALS[‘ecs’]->table(‘cart’) . ” SET goods_number = ‘$number’ WHERE rec_id = $rec_id”;
  • $GLOBALS[‘db’]->query($sql);
  • $subtotal = $GLOBALS[‘db’]->getONE(“select goods_price * goods_number AS subtotal from “.$GLOBALS[‘ecs’]->table(‘cart’).” where rec_id = $rec_id”);
  • $cart_amount = cart_amount(”,$_SESSION[‘flow_type’]);
  • $result[‘subtotal’] = price_format($subtotal, false);
  • $result[‘cart_amount’] = price_format($cart_amount, false);
  • $result[‘rec_id’] = $rec_id;
  • die($json->encode($result));
  • }
  • 还等什么?马上清空echsop的缓存刷新页面看看效果吧。
资源下载此资源仅限注册用户下载,请先
客服QQ:1427707223
收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

免责声明   ⚠️ 1. 本站所有资源来源于网络收集,若资源侵犯了您的合法权益, 请来信通知我们(Email: 1427707223@qq.com),我们会及时删除,给您带来的不便,我们深表歉意! 2. 分享目的仅供大家学习和交流,若使用商业用途,请购买正版授权! 否则产生的一切后果将由下载用户自行承担! 3. 会员不得使用于非法商业用途,不得违反国家法律。否则后果自负! 4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解! 5. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需! 6. 因源码具有可复制性,一经购买 ,不得以任何形式退款。 7.更多详情请点击查看

优站网 ECSHOP教程 通过AJAX方式动态更新ecshop购物车页面的商品数量 https://www.zhanceo.com/15954.html

诚乃立身之本、信为道德之基

常见问题
  • 如果付款后没有弹出下载页面,多刷新几下,有问题联系客服!
查看详情
  • 本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。
查看详情

相关文章

联系官方客服

为您解决烦忧 - 24小时在线 专业服务

通过AJAX方式动态更新ecshop购物车页面的商品数量-海报