• 设为首页
  • 收藏本站
  • 积分充值
  • VIP赞助
  • 手机版
  • 微博
  • 微信
    微信公众号 添加方式:
    1:搜索微信号(888888
    2:扫描左侧二维码
  • 快捷导航
    福建二哥 门户 查看主题

    ecshop二次开发 购物时为每件商品添加备注信息的修改方法

    发布者: 天下网吧 | 发布时间: 2025-7-24 15:58| 查看数: 71| 评论数: 0|帖子模式

    目标: 
    用户在选购商品加入购物车前可以为商品添加备注信息 
    加入购物车后可以在购物车查看备注信息 
    店主在查看订单时可以看到用户为商品添加的备注信息 
    用户在个人中心中可以看到商品的备注信息 
    目标一: 
      打开ecshop/goods.php,搜索"display"可以看到这句: 

    $smarty->display('goods.dwt', $cache_id); 
       
      打开模板目录下的goods.dwt,搜索"",在这句之前添加: 


    商品备注: 
       
      打开ecshop数据库执行: 

    ALTER TABLE `ecs_cart` ADD `content` TEXT NOT NULL 
       
      在下面我们可以看到a连接执行的是:javascript:addToCart({$goods.goods_id}),于是我们在文件夹里查找addToCart方法,在js/common.js里面的addToCart方法我们可以看到表单的值都是在这里获取的,于是我们找到goods.quick = quick;在它前面加上: 

    goods.content= formBuy.elements['content'].value; 
       
    在方法的最后一看可以看到递交的地址是:flow.php?step=add_to_cart. 
      打开flow.php,查找add_to_cart方法,找到if (addto_cart($goods->goods_id, $goods->number, $goods->spec, $goods->parent)),将它替换为: 

    if (addto_cart($goods->goods_id, $goods->number, $goods->spec, $goods->parent,$goods->content)) 
       
      找到addto_cart方法,在includes/lib_order.php里面,将function addto_cart($goods_id, $num = 1, $spec = array(), $parent = 0)替换为: 

    function addto_cart($goods_id, $num = 1, $spec = array(), $parent = 0, $content='') 
      找到$parent['parent_id'] = 0;在它下面加入: 

    $parent['content'] = $content; 
       
    这时候我们回到商品页检查一下是否能运行,填写留言,加入购物车,查看数据库我们可以发现已经成功插入数据库了. 
    但是我们回到商品页重新填写备注信息再加入购物车发现,数据库的备注信息还是原来的,没有更新. 
    于是我们找到" , goods_price = '$goods_price'". ,将它替换为: 

    " , goods_price = '$goods_price', content='$content'". 
    再回到商品页测试,成功更新数据库!我们将商品删除,数据库的记录也消失了! 

    目标二: 

      找到模板目录下的flow.dwt,搜索[td]{$goods.goods_attr|nl2br}[/td],将它替换为: 
    复制代码
    代码如下:

    [td] 
    {$goods.goods_attr|nl2br} 

     
    备注信息:{$goods.content} 
     
    [/td] 

      回到购物车页面刷新,我们发现备注信息已经显示出来了! 

    目标三: 

      进入数据库执行: 

    ALTER TABLE `ecs_order_goods` ADD `content` TEXT NOT NULL 
       
      由checkout页面的提交按钮可以知道它的提交动作为done. 
      在flow.php搜索done,往下找到"/* 插入订单商品 */",修改$sql为: 

    $sql = "INSERT INTO " . $ecs->table('order_goods') . "( " . 
    "order_id, goods_id, goods_name, content, goods_sn, product_id, goods_number, market_price, ". 
    "goods_price, goods_attr, is_real, extension_code, parent_id, is_gift, goods_attr_id) ". 
    " SELECT '$new_order_id', goods_id, goods_name, content, goods_sn, product_id, goods_number, market_price, ". 
    "goods_price, goods_attr, is_real, extension_code, parent_id, is_gift, goods_attr_id". 
    " FROM " .$ecs->table('cart') . 
    " WHERE session_id = '".SESS_ID."' AND rec_type = '$flow_type'"; 
       
    插入订单动作完成! 

      在admin文件夹下找到order.php,在$_REQUEST['act'] == 'info'里的$smarty->display('order_info.htm');可以知道输出的模板为order_info.htm, 
    打开order_info.htm,找到[td]{$goods.goods_attr|nl2br}[/td],替换为: 
    复制代码
    代码如下:

    [td] 
    {$goods.goods_attr|nl2br} 

     
    备注信息:{$goods.content} 
     
    [/td] 
       
    后台订单查看部分完成! 

    来源:互联网
    免责声明:如果侵犯了您的权益,请联系站长(1277306191@qq.com),我们会及时删除侵权内容,谢谢合作!

    最新评论

    QQ Archiver 手机版 小黑屋 福建二哥 ( 闽ICP备2022004717号|闽公网安备35052402000345号 )

    Powered by Discuz! X3.5 © 2001-2023

    快速回复 返回顶部 返回列表