大地阳光 發表於 2023-6-17 00:00:00

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

<p>
由于很多用户需要加上商品自定义吃寻大小等 如图</p>
<p>
<img style="max-width:100%!important;height:auto!important;"title="ecshop 二次开发 加入用户定制商品类型的方法" alt="ecshop 二次开发 加入用户定制商品类型的方法" src="https://zhuji.jb51.net/uploads/img/202305/ace52752c4739efa0da6106db46922e9.jpg"></p>
<p>
<span>首先在\admin\templates\goods_info.htm里面找到 属性与规格 的位置 发现他调用了{$goods_attr_html}这个页面, </span><br><br><span>这个函数的定义在\admin\goods.php 的第444行 </span><br><br><span>$smarty-&amp;gt;assign('goods_attr_html', build_attr_html($goods['goods_type'], $goods['goods_id'])); </span><br><span>&amp;nbsp; </span><br><br><span>然后找build_attr_html这个函数,在\admin\includes\lib_goods.php的675行 </span><br><br><span>在if语句中加上 </span><br><span>|| $val['attr_type'] == 3 </span><br><span>&amp;nbsp; </span><br><br><span>这样就可以在\admin\templates\attribute_info.htm 里面的55行 </span><br><br><span>加入 </span><br><span>input type="radio" name="attr_type" value="3" {if $attr.attr_type eq 3} checked="true" {/if} // 自定义属性 </span><br><span>然后在添加属性的时候选中这项。 </span><br><br><span>下来在前台即\themes\default\goods.dwt搜”判断属性是复选还是单选“,在循环里加入 </span></p>
<div>

<p>
代码如下:</p>
</div>
<div id="phpcode18">
<br>
&lt;!--{elseif $spec.attr_type eq 3}--&gt; <br>
&lt;!-- {foreach from=$spec.values item=value key=key} --&gt; <br>
&lt;label for="spec_value_{$value.id}"&gt; <br>
&lt;input type='text' name="spec_{$spec_key}" id="{$value.id}" onclick="changePrice()" /&gt; <br>
{$value.label} [{if $value.price gt 0}{$lang.plus}{elseif $value.price lt 0}{$lang.minus}{/if} {$value.format_price|abs}] &lt;/label&gt;<br><br>
&lt;!-- {/foreach} --&gt; <br>
&lt;input type="hidden" name="spec_list" value="{$key}" /&gt; </div>
<p>
<br><span>现在,我们就要修改后台代码使用户输入后写入数据库中。 </span><br><br><span>为了使输入数据库中时顺序不错乱,首先要修改数据库的ecs_goods_attr这个表,在末尾添加attr_itype表单,设置为int,默认为0。 </span><br><br><span>下来还得去\admin\includes\lib_goods.php里面,在function build_attr_html这个函数找到 </span></p>
<div>

<p>
代码如下:</p>
</div>
<div id="phpcode19">
<br>
$html .= ($val['attr_type'] == 1 || $val['attr_type'] == 2) ? <br>
$GLOBALS['_LANG']['spec_price'].' &lt;input type="text" name="attr_price_list[]" value="' . $val['attr_price'] . '" size="5" maxlength="10" /&gt;' : <br>
' &lt;input type="hidden" name="attr_price_list[]" value="0" /&gt;'; </div>
<p>
<br><span>在这行后面紧接着添加一行 </span><br><br><span>$html .= ' &lt;input type="hidden" name="attr_itype_list[]" value="' . $val['attr_type'] . '" /&gt;' ; </span><br><br><span>现在再去\admin\goods.php 找到 </span></p>
<div>

<p>
代码如下:</p>
</div>
<div id="phpcode20">
<br>
$attr_value = $_POST['attr_value_list'][$key]; <br>
$attr_price = $_POST['attr_price_list'][$key]; </div>
<p>
<br><span>这两行,在启后面紧接着添加一行 </span><br><br><span>$attr_itype = $_POST['attr_itype_list'][$key]; </span><br><br><span>再找到 /* 插入、更新、删除数据 */注释后面的那个循环,将第一个if和其中的内容改为 </span><br>
 </p>
<div>

<p>
代码如下:</p>
</div>
<div id="phpcode21">
<br>
if ($info['sign'] == 'insert') <br>
{ <br>
$sql = "INSERT INTO " .$ecs-&gt;table('goods_attr'). " (attr_id, goods_id, attr_value, attr_price,attr_itype)". <br>
"VALUES ('$attr_id', '$goods_id', '$attr_value', '$info','$attr_itype')"; <br>
} </div>
<p>
<br><span>这样就在添加商品属性的时候在数据库中把属性所属的类别附在了后面,在调用的时候可以根据类别来寻找text输入框的内容然后写入。后台部分结束,下来修改前台的用户提交部分。 </span><br><span>首先要修改的是\js\common.js这个文件,找到function getSelectedAttributes这个函数,将之改为 </span></p>
<div>

<p>
代码如下:</p>
</div>
<div id="phpcode22">
<br>
function getSelectedAttributes(formBuy) <br>
{ <br>
var spec_arr = new Array( new Array(),new Array()); <br>
var j = 0; <br>
var ki = 0; <br>
for (i = 0; i &lt; formBuy.elements.length; i ++ ) <br>
{ <br>
var prefix = formBuy.elements.name.substr(0, 5); <br>
if (prefix == 'spec_' &amp;&amp; ( <br>
((formBuy.elements.type == 'radio' || formBuy.elements.type == 'checkbox') &amp;&amp; formBuy.elements.checked) || <br>
formBuy.elements.tagName == 'SELECT')) <br>
{ <br>
spec_arr = formBuy.elements.value; <br>
j++ ; <br>
} <br>
if (prefix == 'spec_' &amp;&amp; formBuy.elements.type == 'text' ) <br>
{ <br>
spec_arr = formBuy.elements.id; <br>
spec_arr = formBuy.elements.value; <br>
j ++; <br>
ki ++; <br>
} <br>
} <br>
return spec_arr; <br>
} </div>
<p>
<br><span>再在function addToCart这个函数里将 </span><br><span>goods.spec = spec_arr; </span><br><span>改为 </span><br><span>goods.spec = spec_arr; </span><br><span>goods.desc = spec_arr; </span><br><span>这样,表单提交的时候就多了一个type为text的input框的值,由上述函数得知表单提交到的根目录下的flow.php文件,找到 </span><br><span>if (addto_cart($goods-&gt;goods_id, $goods-&gt;number, $goods-&gt;spec, $goods-&gt;parent)) </span><br><span>这句,将之改为 </span><br><span>if (addto_cart($goods-&gt;goods_id, $goods-&gt;number, $goods-&gt;spec, $goods-&gt;parent,$goods-&gt;desc)) </span><br><span>再到\include\lib_order.php里面,在适当位置写入下述函数 </span><br>
 </p>
<div>

<p>
代码如下:</p>
</div>
<div id="phpcode23">
<br>
function get_goods_attr_info2($arr,$desc) <br>
{ <br>
$attr = ''; <br>
if (!empty($arr)) <br>
{ <br>
$fmt = "%s:%s %s\n"; <br>
$fmt2 = "%s:%s[%s]\n"; <br>
$sql = "SELECT a.attr_name, ga.attr_value, ga.attr_price, ga.attr_itype ". <br>
"FROM ".$GLOBALS['ecs']-&gt;table('goods_attr')." AS ga, ". <br>
$GLOBALS['ecs']-&gt;table('attribute')." AS a ". <br>
"WHERE " .db_create_in($arr, 'ga.goods_attr_id')." AND a.attr_id = ga.attr_id"; <br>
$res = $GLOBALS['db']-&gt;query($sql); <br>
$i=0; <br>
while ($row = $GLOBALS['db']-&gt;fetchRow($res)) <br>
{ <br>
if($row['attr_itype']==3) <br>
{ <br>
$attr_price = round(floatval($row['attr_price']), 2); <br>
$attr .= sprintf($fmt, $row['attr_name'], $row['attr_value'], $desc[$i]); <br>
$i++; <br>
} <br>
else <br>
{ <br>
$attr_price = round(floatval($row['attr_price']), 2); <br>
$attr .= sprintf($fmt2, $row['attr_name'], $row['attr_value'],$attr_price); <br>
} <br>
} <br>
$attr = str_replace('', '', $attr); <br>
} <br>
return $attr; <br>
} </div>
<p>
<br><span>再去 </span><br><span>$goods_attr = get_goods_attr_info($spec); </span><br><span>这行,将get_goods_attr_info($spec)改为get_goods_attr_info2($spec,$desc),即调用刚写入的那个函数并把input用户输入的东西传进去。 </span><br><span>之后前台自行修改即可</span></p>
頁: [1]
查看完整版本: ecshop 二次开发 加入用户定制商品类型的方法