欢迎来到素材无忧网,按 + 收藏我们
登录 注册 退出 找回密码

ecshop商品属属性定制定做,属性批量购买教程

时间: 2024-02-25 10:43 阅读: 作者:素材无忧网

由于很多用户需要加上商品自定义吃寻大小等首先在admintemplatesgoods_info.htm里面找到 属 与规格 的位置 发现他调用了{$goods_attr_html}这个页面,这个函数的定义在admingoods.php 的第444行
$smarty->assign('goods_attr_html', build_attr_html($goods['goods_type'], $goods['goods_id']));
;
然后找build_attr_html这个函数,在adminincludeslib_goods.php的675行
在if语句中加上
|| $val['attr_type'] == 3
;
这样就可以在admintemplatesattribute_info.htm 里面的55行
加入
input type="radio" name="attr_type" value="3" {if $attr.attr_type eq 3} checked="true" {/if} // 自定义属
然后在添加属 的时候选中这项。
下来在前台即themesdefaultgoods.dwt搜"判断属 是复选还是单选",在循环里加入
代码如下:




 
现在,我们就要修改后台代码使用户输入后写入数据库中。
为了使输入数据库中时顺序不错乱,首先要修改数据库的ecs_goods_attr这个表,在末尾添加attr_itype表单,设置为int,默认为0。
下来还得去adminincludeslib_goods.php里面,在function build_attr_html这个函数找到
代码如下:
$html .= ($val['attr_type'] == 1 || $val['attr_type'] == 2) ?
$GLOBALS['_LANG']['spec_price'].' ' :
' '; 在这行后面紧接着添加一行
$html .= ' ' ;
现在再去admingoods.php 找到
代码如下:
$attr_value = $_POST['attr_value_list'][$key];
$attr_price = $_POST['attr_price_list'][$key];
这两行,在启后面紧接着添加一行
$attr_itype = $_POST['attr_itype_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输入框的内容然后写入。后台部分结束,下来修改前台的用户提交部分。
首先要修改的是jscommon.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;
}
再在function addToCart这个函数里将
goods.spec = spec_arr;
改为
goods.spec = spec_arr[0];
goods.desc = spec_arr[1];
这样,表单提交的时候就多了一个type为text的input框的值,由上述函数得知表单提交到的根目录下的flow.php文件,找到
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->desc))
再到includelib_order.php里面,在适当位置写入下述函数
代码如下:
function get_goods_attr_info2($arr,$desc)
{
$attr = '';
if (!empty($arr))
{
$fmt = "%s:%s %sn";
$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;
} 
再去
$goods_attr = get_goods_attr_info($spec);
这行,将get_goods_attr_info($spec)改为get_goods_attr_info2($spec,$desc),即调用刚写入的那个函数并把input用户输入的东西传进去。
之后前台自行修改即可

版权声明: 本站资源均来自互联网或会员发布,如果侵犯了您的权益请与我们联系,我们将在24小时内删除!谢谢!

转载请注明: ecshop商品属属性定制定做,属性批量购买教程

标签: ecshop商品  
推荐文章
模板推荐