iis服务器助手广告广告
返回顶部
首页 > 资讯 > CMS >ecshop二次开发 购物时为每件商品添加备注信息的修改方法
  • 405
分享到

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

商品备注信息 2022-06-12 02:06:52 405人浏览 泡泡鱼
摘要

目标: 用户在选购商品加入购物车前可以为商品添加备注信息 加入购物车后可以在购物车查看备注信息 店主在查看订单时可以看到用户为商品添加的备注信息 用户在个人中心中可以看到商品的备注信息 目标一:   打开ecshop/G

目标:

用户在选购商品加入购物车前可以为商品添加备注信息

加入购物车后可以在购物车查看备注信息

店主在查看订单时可以看到用户为商品添加的备注信息

用户在个人中心中可以看到商品的备注信息

目标一:

  打开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>

  

后台订单查看部分完成!

--结束END--

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

本文链接: https://www.lsjlt.com/news/32452.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作