ecshop-加入用户定制商品类型的方法-二次开发

教程大全 2026-01-08 18:33:20 浏览

由于很多用户需要加上商品自定义吃寻大小等 如图

首先在\admin\templates\goods_info.htm里面找到 属性与规格 的位置 发现他调用了{$goods_attr_html}这个页面, 这个函数的定义在\admin\goods.PHP 的第444行 然后找build_attr_html这个函数,在\admin\includes\lib_goods.php的675行 这样就可以在\admin\templates\attribute_info.htm 里面的55行 然后在添加属性的时候选中这项。 下来在前台即\themes\default\goods.dwt搜”判断属性是复选还是单选“,在循环里加入

代码如下:

现在,我们就要修改后台代码使用户输入后写入数据库中。 为了使输入数据库中时顺序不错乱,首先要修改数据库的ecs_goods_attr这个表,在末尾添加attr_itype表单,设置为int,默认为0。 下来还得去\admin\includes\lib_goods.php里面,在function build_attr_html这个函数找到

代码如下:

$html .= ($val['attr_type'] == 1 || $val['attr_type'] == 2) ?$GLOBALS['_LANG']['spec_price'].' ' :' ';

在这行后面紧接着添加一行

代码如下:

$attr_value = $_POST['attr_value_list'][$key];$attr_price = $_POST['attr_price_list'][$key];

这两行,在启后面紧接着添加一行 再找到 /* 插入、更新、删除数据 */注释后面的那个循环,将第一个if和其中的内容改为

代码如下:

if ($info['sign'] == 'insert'){$Sql = "INSERT INTO " .$ecs->table('goods_attr'). " (attr_id, goods_id, attr_value, attr_price,attr_itype)"."VALUES ('$attr_id', '$goods_id', '$attr_value', '$info[attr_price]','$attr_itype')";}

这样就在添加商品属性的时候在数据库中把属性所属的类别附在了后面,在调用的时候可以根据类别来寻找text输入框的内容然后写入。后台部分结束,下来修改前台的用户提交部分。 首先要修改的是\js\common.js这个文件,找到function getSelectedAttributes这个函数,将之改为

代码如下:

function getSelectedAttributes(formBuy){var spec_arr = new Array( new Array(),new Array());var j = 0;var ki = 0;for (i = 0; i < formBuy.elements.length; i ++ ){var prefix = formBuy.elements[i].Name.substr(0, 5);if (prefix == 'spec_' && (((formBuy.elements[i].type == 'radio' || formBuy.elements[i].type == 'checkbox') && formBuy.elements[i].checked) ||formBuy.elements[i].tagName == 'SELECT')){spec_arr[0][j] = formBuy.elements[i].value;j++ ;}if (prefix == 'spec_' && formBuy.elements[i].type == 'text' ){spec_arr[0][j] = formBuy.elements[i].id;spec_arr[1][ki] = formBuy.elements[i].value;j ++;ki ++;}}return spec_arr;}

这样,表单提交的时候就多了一个type为text的input框的值,由上述函数得知表单提交到的根目录下的flow.php文件,找到 再到\include\lib_order.php里面,在适当位置写入下述函数

ecshop

代码如下:

function get_goods_attr_info2($arr,$desc){$attr = '';if (!empty($arr)){$fmt = "%s:%s %s\n";$fmt2 = "%s:%s[%s]\n";$sql = "SELECT a.attr_name, ga.attr_value, ga.attr_price, ga.attr_itype "."FROM ".$GLOBALS['ecs']->table('goods_attr')." AS ga, ".$GLOBALS['ecs']->table('attribute')." AS a "."WHERE " .db_create_in($arr, 'ga.goods_attr_id')." AND a.attr_id = ga.attr_id";$res = $GLOBALS['db']->query($sql);$i=0;while ($row = $GLOBALS['db']->fetchRow($res)){if($row['attr_itype']==3){$attr_price = round(floatval($row['attr_price']), 2);$attr .= sprintf($fmt, $row['attr_name'], $row['attr_value'], $desc[$i]);$i++;}else{$attr_price = round(floatval($row['attr_price']), 2);$attr .= sprintf($fmt2, $row['attr_name'], $row['attr_value'],$attr_price);}}$attr = str_replace('[0]', '', $attr);}return $attr;}

这行,将get_goods_attr_info($spec)改为get_goods_attr_info2($spec,$desc),即调用刚写入的那个函数并把input用户输入的东西传进去。 之后前台自行修改即可

本文版权声明本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,请联系本站客服,一经查实,本站将立刻删除。

发表评论

热门推荐