下载鸥 > 网站下载 > 开发教程 > 帝国CMS

帝国ECMS怎样实现AJAX无刷新加入购物车?

368 2021-03-12 12:37:58

收藏
ajax在数据交互中用户体验非常好,在一些不需要刷新页面的情况下,使用ajax体验远远好于刷新页面。那么,帝国ECMS在做商城功能时,怎样实现AJAX无刷新加入购物车呢?
 
1、修改商城内容模板,头部加入如下代码:
<script type="text/javascript" src="/static/js/jquery.js"></script>
<script type="text/javascript" src="/static/js/addBuyCar.js"></script>
<script type="text/javascript">
var newsurl='<?=$public_r[newsurl]?>';
</script>

2、修改商城内容模板,加入购物车部分修改成如下代码:
代码如下:
<a href="#ecms" onclick="AddProduct([!--classid--],[!--id--]);">加入购物车</a>

3、jquery文件,兼容1.3和1.4版本,自行下载。文件addBuyCar.js源代码如下:
代码如下:
function AddProduct(classid,id) {
    $.ajax({
        type: "post",
        url: newsurl+"e/template/ShopSys/addBuyCar.php",
        data:"classid="+classid+"&id="+id,
        dataType: "json",
        success: function (json) {
            alert(json.msg);
        }
    })
}

4、创建无刷新加入购物车接口文件,目录如下
/e/template/ShopSys/addBuyCar.php

5、接口文件源代码如下
<?php
require("../../class/connect.php");
require("../../class/db_sql.php");
require("../../data/dbcache/class.php");
require("../../class/ShopSysFun.php");
$link=db_connect();
$empire=new mysqlquery();
$classid=(int)$_POST['classid'];
$id=(int)$_POST['id'];
function json_AddBuycar($classid,$id){
global $class_r,$empire,$dbtbpre,$public_r;
$classid=(int)$classid;
$id=(int)$id;
if(empty($classid)||empty($id)||empty($class_r[$classid][tbname]))
{
    return json_encode(array('msgid'=>1,'msg'=>'此商品不存在'));
}
//验证产品是否存在
$num=$empire->gettotal("select count(*) as total from {$dbtbpre}ecms_".$class_r[$classid][tbname]." where classid='$classid' and id='$id' limit 1");
if(!$num)
{
    return json_encode(array('msgid'=>1,'msg'=>'此商品不存在'));
}
$record="!";
$field="|";
$productid=$classid.",".$id;
$buycar=getcvar('mybuycar');
//重复
if(strstr($buycar,"|".$productid."|"))
{
    $pr=explode("|".$productid."|",$buycar);
    $pr1=explode("!",$pr[1]);
    $oldbuycar="|".$productid."|".$pr1[0]."!";
    //数量
    $pr1[0]=ReturnBuycarProductNum($pr1[0]);
    if(empty($pr1[0]))
    {
        $pr1[0]=1;
    }
    $newnum=$pr1[0]+1;
    $newbuycar="|".$productid."|".$newnum."!";
    $buycar=str_replace($oldbuycar,$newbuycar,$buycar);
}
else
{
    //只存放一个
    if($public_r['buycarnum']==1)
    {
        $buycar='';
    }
        $buycar.="|".$productid."|1!";
    }
    $re=SetBuycar($buycar);
    if($re)
    {
        return json_encode(array('msgid'=>2,'msg'=>'商品加入购物车成功'));
    }
}
echo json_AddBuycar($classid,$id);
db_close();
$empire=null;
?>

这样,我们就实现了帝国cms商城系统ajax无刷新加入购物车的功能了。
 

注意

非专业人员操作前务必备份数据。

本文地址:https://xzo.com.cn/develop/empire/690.html

有帮助,很赞!

信息来源:下载鸥
导出教程 下载word版教程
发表评论 共有条评论
关于帝国CMS


帝国cms是一款功能极为强大的cms程序,性能强悍、安全性高,可轻松支持10万数据,高级开发人员可制作出能容纳千万数据量的网站,是国内最出色的开源cms程序之一,推荐企业用户使用

当前最新版本为7.5,8.0版本即将上线,新版本的核心优化点在于多终端的适配。

推荐帝国CMS开发教程
帝国CMS怎样批量取消文章审核
帝国CMS怎样批量取消文章审核

使用帝国CMS的朋友可能有这样的需求:由于信息发生变化,或是数据出了问题,想要...

7 675
帝国CMS开发的网站怎样修改网站标题关键词和描述?
帝国CMS开发的网站怎样修改网站标题关键词和描述?

在网站运营的过程中,由于业务的变更或是优化的需要,可能需要修改网站的标题,关...

1 538
帝国CMS精准像素美化版怎样修改网站名
帝国CMS精准像素美化版怎样修改网站名

帝国CMS官方默认后台挺难看的,如果自用还可以,给客户则可能让客户怀疑你的审...

1 448
帝国cms怎样批量删除垃圾留言?
帝国cms怎样批量删除垃圾留言?

现如今,许多商家通过机器批量给网站发留言,一条两条还可以接受,有的商家却是拼...

1 495
帝国cms显示的发布时间与实际发布时间相差了8小时怎么办?
帝国cms显示的发布时间与实际发布时间相差了8小时怎么办?

有少量客户在使用帝国cms建站时发现一个问题:帝国cms显示的发布时间与真实的...

0 437
帝国cms禁止蜘蛛抓取后台提升网站安全
帝国cms禁止蜘蛛抓取后台提升网站安全

后台是网站安全的重中之重,而帝国cms后台路径可以修改让得网站安全度大为提...

1 541
帝国cms网站宝塔面板忘记登陆地址了怎么办?
帝国cms网站宝塔面板忘记登陆地址了怎么办?

宝塔面板是一款非常好用的服务器管理软件,但在安装完宝塔后,有些人可能会忘记...

0 424
帝国cms怎样给广告增加排序?
帝国cms怎样给广告增加排序?

帝国cms广告系统功能比较强大,但本身并没有排序的功能。如果想要替换广告的...

3 482
推荐插件
帝国cms在线考试系统模板插件
帝国cms在线考试系统模板插件

一直没看到好用的帝国cms在线考试插件,所以自己开发了一款。在线考试插件用...

0 1285
帝国cms批量添加后台用户插件
帝国cms批量添加后台用户插件

使用帝国cms的企业用户、新闻资讯类站点的用户很多,此类站点很多时候需要有...

0 782
帝国CMS内网用户静态站点文章访客统计插件
帝国CMS内网用户静态站点文章访客统计插件

本插件适用于内网用户,可查看单篇文章访问者ip地址。如果添加访问者ip组,可查...

0 565
帝国cms联想词搜索高级搜索插件下载
帝国cms联想词搜索高级搜索插件下载

帝国CMS自带的搜索功能虽然强大,但也有很强的局限性 -- 必须关键词完全匹配...

0 736
帝国cms百度文字识别ocr接口对接插件
帝国cms百度文字识别ocr接口对接插件

许多网站会做一些小功能小插件给客户使用以增强用户黏性,比如图片转文字,这种...

0 472
帝国cms智能自动审核按星期几审核指定栏目带推送插件
帝国cms智能自动审核按星期几审核指定栏目带推送插件

采集站的必备资源是自动审核,要做到日收录也离不开定时发布。而本插件的自动...

0 1285
帝国cms纳米数据接口(足球比赛中最新数据)
帝国cms纳米数据接口(足球比赛中最新数据)

帝国cms 对接纳米数据(www.nami.com)接口,本接口主要接收、整理足球比赛实时数...

0 423
帝国cms百度AI图像去雾api接口对接插件
帝国cms百度AI图像去雾api接口对接插件

通过本插件,可以实现帝国cms网站对接百度云api实现图像去雾的功能。经过实际...

0 460
客服QQ:341553759
扫码咨询 常见问题 >
官方交流群:90432500
点击加入