ecshop 二次開發(fā) 加入用戶定制商品類型的方法

字號(hào):


    由于很多用戶需要加上商品自定義吃尋大小等 如圖
    名單
    首先在\admin\templates\goods_info.htm里面找到 屬性與規(guī)格 的位置 發(fā)現(xiàn)他調(diào)用了{(lán)$goods_attr_html}這個(gè)頁面,
    這個(gè)函數(shù)的定義在\admin\goods.php 的第444行
    $smarty->assign('goods_attr_html', build_attr_html($goods['goods_type'], $goods['goods_id']));
     
    然后找build_attr_html這個(gè)函數(shù),在\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} // 自定義屬性
    然后在添加屬性的時(shí)候選中這項(xiàng)。
    下來在前臺(tái)即\themes\default\goods.dwt搜”判斷屬性是復(fù)選還是單選“,在循環(huán)里加入
    代碼如下:
    <!--{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}" />
    現(xiàn)在,我們就要修改后臺(tái)代碼使用戶輸入后寫入數(shù)據(jù)庫中。
    為了使輸入數(shù)據(jù)庫中時(shí)順序不錯(cuò)亂,首先要修改數(shù)據(jù)庫的ecs_goods_attr這個(gè)表,在末尾添加attr_itype表單,設(shè)置為int,默認(rèn)為0。
    下來還得去\admin\includes\lib_goods.php里面,在function build_attr_html這個(gè)函數(shù)找到
    代碼如下:
    $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'] . '" />' ;
    現(xiàn)在再去\admin\goods.php 找到
    代碼如下:
    $attr_value = $_POST['attr_value_list'][$key];
    $attr_price = $_POST['attr_price_list'][$key];
    這兩行,在啟后面緊接著添加一行
    $attr_itype = $_POST['attr_itype_list'][$key];
    再找到 /* 插入、更新、刪除數(shù)據(jù) */注釋后面的那個(gè)循環(huán),將第一個(gè)if和其中的內(nèi)容改為
    復(fù)制代碼代碼如下:
    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')";
    }
    這樣就在添加商品屬性的時(shí)候在數(shù)據(jù)庫中把屬性所屬的類別附在了后面,在調(diào)用的時(shí)候可以根據(jù)類別來尋找text輸入框的內(nèi)容然后寫入。后臺(tái)部分結(jié)束,下來修改前臺(tái)的用戶提交部分。
    首先要修改的是\js\common.js這個(gè)文件,找到function getSelectedAttributes這個(gè)函數(shù),將之改為
    代碼如下:
    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這個(gè)函數(shù)里將
    goods.spec = spec_arr;
    改為
    goods.spec = spec_arr[0];
    goods.desc = spec_arr[1];
    這樣,表單提交的時(shí)候就多了一個(gè)type為text的input框的值,由上述函數(shù)得知表單提交到的根目錄下的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里面,在適當(dāng)位置寫入下述函數(shù)
    復(fù)制代碼代碼如下:
    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),即調(diào)用剛寫入的那個(gè)函數(shù)并把input用戶輸入的東西傳進(jìn)去。
    之后前臺(tái)自行修改即可