zoukankan      html  css  js  c++  java
  • ecshop二次开发购物时为每件商品添加备注信息

    简介:这是ecshop二次开发--购物时为每件商品添加备注信息的详细页面,介绍了和php,有关的知识、技巧、经验,和一些php源码等。

    class='pingjiaF' frameborder='0' src='http://biancheng.dnbcw.info/pingjia.php?id=345841' scrolling='no'>

    目标:

    1. 用户在选购商品加入购物车前可以为商品添加备注信息
    2. 加入购物车后可以在购物车查看备注信息
    3. 店主在查看订单时可以看到用户为商品添加的备注信息
    4. 用户在个人中心中可以看到商品的备注信息

    目标一:

      打开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}
                  	<br />
                    <!--{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}
            <br />
            <!--{if $goods.content}-->
                备注信息:{$goods.content}
            <!--{/if}-->
        </td>
    

      

    后台订单查看部分完成!

    目标四:

    参考目标二自行完成~

    爱J2EE关注Java迈克尔杰克逊视频站JSON在线工具

    http://biancheng.dnbcw.info/php/345841.html pageNo:4
  • 相关阅读:
    Hibernate注解(一对一、一对多、多对多)
    Hibernate多表关系配置——继承
    Hibernate多表关系配置——多对多对关系映射
    Hibernate多表关系配置——一对一关系映射
    Hibernate多表关系配置——多对一关系映射
    初识Hibernate——添加数据
    Servlet学习总结
    jQuery动态添加Table行
    VS2013搭建CSDN源代码管理git
    Node.js amqplib 连接 Rabbitmq 学习笔记
  • 原文地址:https://www.cnblogs.com/ooooo/p/2240601.html
Copyright © 2011-2022 走看看