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

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

首先在\admin\templates\goods_info.htm里面找到 属性与规格 的位置 发现他调用了{$goods_attr_html}这个页面,

这个函数的定义在\admin\goods.php 的第444行

$smarty->assign('goods_attr_html', build_attr_html($goods['goods_type'], $goods['goods_id']));

然后找build_attr_html这个函数,在\admin\includes\lib_goods.php的675行

在if语句中加上 
|| $val['attr_type'] == 3

这样就可以在\admin\templates\attribute_info.htm 里面的55行

加入 
input type="radio" name="attr_type" value="3" {if $attr.attr_type eq 3} checked="true" {/if} // 自定义属性 
然后在添加属性的时候选中这项。

下来在前台即\themes\default\goods.dwt搜”判断属性是复选还是单选“,在循环里加入

代码如下:
<!--{elseif $spec.attr_type eq 3}--> 
<!-- {foreach from=$spec.values item=value key=key} --> 
<label for="spec_value_{$value.id}"> 
<input type='text' name="spec_{$spec_key}" id="{$value.id}" onclick="changePrice()" /> 
{$value.label} [{if $value.price gt 0}{$lang.plus}{elseif $value.price lt 0}{$lang.minus}{/if} {$value.format_price|abs}] </label>

<!-- {/foreach} --> 
<input type="hidden" name="spec_list" value="{$key}" />

现在,我们就要修改后台代码使用户输入后写入数据库中。

为了使输入数据库中时顺序不错乱,首先要修改数据库的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'].' <input type="text" name="attr_price_list[]" value="' . $val['attr_price'] . '" size="5" maxlength="10" />' : 
' <input type="hidden" name="attr_price_list[]" value="0" />';

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

$html .= ' <input type="hidden" name="attr_itype_list[]" value="' . $val['attr_type'] . '" />' ;

现在再去\admin\goods.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输入框的内容然后写入。后台部分结束,下来修改前台的用户提交部分。 
首先要修改的是\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; 
}

再在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)) 
再到\include\lib_order.php里面,在适当位置写入下述函数

代码如下:
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; 
}

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

文章转载:http://www.gehut.cn/

(0)

相关推荐

  • ThinkPHP5+Redis实现购物车

    本篇文章是通过ThinkPHP5和Redis实现购物车,功能包括:购物车列表.添加购物车.获取部分商品.获取部分商品总数量.获取全部商品总数量.商品减一.修改商品数量.删除商品.清空购物车,这些功能基 ...

  • 【编程课堂】以 jQuery 之名 - 爬虫利器 PyQuery

    很多读者在学习了 Python 之后都想做一些爬虫程序,去网上采集数据或完成一些自动化操作.因此,我们也制作了一套爬虫实战课程,目前正在最后的完善中,很快将和各位见面. 等不及的朋友,可以先来看看这个 ...

  • ECSHOP商品订单自动确认二次开发教程

    通过本教程可以实现ECSHOP商城订单自动确认! 1.运行sql代码,生成数据库 CREATE TABLE `ecs_order_auto_confirm` ( `id` INT(10) UNSIGN ...

  • 让ecshop商品页购买记录显示所购商品属性

    如果某个ecshop商品有好几个颜色,正好赶上有个买家各种颜色都买了1个,而ECSHOP默认的销售记录没有属性这一项,这样就会出现连续好几条购买记录都是同一个买家的,让人看着不舒服. 下面 就以ecs ...

  • ECSHOP商品属性,ECSHOP商品属性筛选

    各位ECSHOP网店系统用户大家好,欢迎来到ECSHOP教程网图文教程,今天为大家详细解说一下ECSHOP商品属性,ECSHOP商品属性筛选设置. ECSHOP教程网ECSHOP视频教程也再不断的完善 ...

  • ecshop商品批量购买批量添加商品到购物车【ECSHOP教程】

    默认的ecshop中只能单件点击"添加到购物车",没有办法批量添加,其实很简单,我们可以用函数 addToCart()来实现.下面我们就来讲一下具体的操作方法. 第一,修改商品列表 ...

  • ECSHOP商品批量购买添加到购物车方法

    ecshop中批量添加商品到购物车.大家都知道,默认的ecshop只能单件点击"添加到购物车"(Add to Cart)实现一件一件的添加商品到购物车,无法经过多选之后批量添加. ...

  • ecshop商品批量购买批量添加商品到购物车

    默认的ecshop中只能单件点击"添加到购物车",没有办法批量添加,其实很简单,我们可以用函数 addToCart()来实现.下面我们就来讲一下具体的操作方法. 第一,修改商品列表 ...

  • ecshop商品批发批量购买插件

    类似效果: 代码: 1.打开goods.dwt加入 <form action="flow.php" method="post" name="EC ...

  • ecshop商品属性仿淘宝选择功能

    经常网友问商品的颜色尺 寸等属性选择,ecshop默认的是下拉菜单和点选两种形式,样式特别不耐看,淘宝选择那种方形的框选已经是主流,像shopex的属性选择就是仿淘宝那 种框选特别美观!下面分享一下e ...

  • ECSHOP商品属性库存关联仿淘宝商品详细页

    效果如下: 实现方法,修改goods.dwt如下: {$value.label} 在显示详细信息合适的地方加 (库存:{$goods.goods_number} {$goods.measure_uni ...