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

所属分类: CMS教程 / ecshop 阅读数: 1960
收藏 0 赞 0 分享
目标:
用户在选购商品加入购物车前可以为商品添加备注信息
加入购物车后可以在购物车查看备注信息
店主在查看订单时可以看到用户为商品添加的备注信息
用户在个人中心中可以看到商品的备注信息
目标一:
  打开ecshop/goods.php,搜索"display"可以看到这句:

$smarty->display('goods.dwt', $cache_id);
  
  打开模板目录下的goods.dwt,搜索"<!-- {* 结束循环可选属性 *} -->",在这句之前添加:

<br />商品备注:<textarea name="content" cols="40" rows="5"></textarea>
  
  打开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 bgcolor="#ffffff">{$goods.goods_attr|nl2br}</td>,将它替换为:

复制代码
代码如下:

<td bgcolor="#ffffff">
{$goods.goods_attr|nl2br}

<!--{if $goods.content}-->
备注信息:{$goods.content}
<!--{/if}-->
</td>

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

目标三:

  进入数据库执行:

ALTER TABLE `ecs_order_goods` ADD `content` TEXT NOT NULL
  
  由checkout页面的提交按钮<input type="hidden" name="step" value="done" />可以知道它的提交动作为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}

<!--{if $goods.content}-->
备注信息:{$goods.content}
<!--{/if}-->
</td>
  
后台订单查看部分完成!
更多精彩内容其他人还在看

ecshop支付宝自动发货接口用法示例

这篇文章主要介绍了ecshop支付宝自动发货接口用法,结合实例形式分析了Ecshop实现支付宝自动发货功能的相关代码修改与接口操作代码功能与修改技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

ecshop实现针对不同支付方式对应不同价格折扣的方法

这篇文章主要介绍了ecshop实现针对不同支付方式对应不同价格折扣的方法,涉及针对Ecshop底层相关逻辑判定代码的修改操作,需要的朋友可以参考下
收藏 0 赞 0 分享

ecshop商品批量上传乱码读CSV的方式问题

ECShop后台用CSV批量上传商品数据包出现一堆乱码,问题相当严重经分析之后发现ECShop读CSV的方式弱爆了,接下来为大家详细介绍下解决方案,感兴趣的各位可以参考下哈
收藏 0 赞 0 分享

ecshop 注册送红包实现代码

有时候我们在使用ecshop过程中,一些推广优惠,这里特分享下实现代码,需要的朋友可以参考下
收藏 0 赞 0 分享

ecshop显示商品按月统计销售数量

统计商品出售总数,和半年或者三个月,一个月的出售数量。复制此函数粘贴到根目录下goods.php末尾。然后回到该文件241行给变量赋值
收藏 0 赞 0 分享

调用ecshop商品顶级分类ID我NAME的二种方法

本文总结一下ecshop 获取所在商品的顶级分类ID及NAME两种方法
收藏 0 赞 0 分享

ecshop数据库ecs_stats短时间内会变很大的解决方法

ecs_stats表是记录访问日志的,短时间内会增加很多数据库存储空间,建议清空日志表所有记录,具体操作步骤如下,大家可以参考下
收藏 0 赞 0 分享

ecshop邮件服务器设置方法

这篇文章主要介绍了ecshop邮件服务器设置方法,需要的朋友可以参考下
收藏 0 赞 0 分享

ecshop购物车消失后产品只能单件购买的解决方法(一步购物设置方法)

这篇文章主要介绍了ecshop一步购物设置方法,下面客户碰到的问题也和一步购物设置有关,这里给出解决方法
收藏 0 赞 0 分享

ecshop数据库备份和数据库恢复的步骤

这篇文章主要介绍了ecshop数据库备份和数据库恢复的步骤,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多