ECSHOP后台商品列表中增加商品属性的显示方法

 

功能:在商品列表上,点击放大镜,显示商品所有属性以及其价格,效果如下:

 

方法/步骤:

1.编辑\admin\templates\goods_list.htm 模板,在

{include file="goods_search.htm"}

下面加入以下代码:

 

2. 查找

{$goods.goods_id})">{$goods.goods_name|escape:html}

在这行代码前面(

border=0 οnclick="zoomImg(this,'{$goods.goods_id}')">

3.拖到底部,在前,插入以下JS函数;

function zoomImg(obj,sortId){

var layer = document.getElementById("zoomImg");

var t=obj.offsetTop;

var l=obj.offsetLeft;

while(obj=obj.offsetParent){

  t+=obj.offsetTop;

  l+=obj.offsetLeft;

}

layer.style.left =l+100;

layer.style.top = t-5;

//layer.style.left =200;

//layer.style.top = 120;

zoomHtml="

('zoomImg').style.display='none'>

colspan=2>";

zoomTime=setTimeout("showZoomImg()",1000);

}

function hideZoomImg(){

var layer = document.getElementById("zoomImg");

clearTimeout(zoomTime);

layer.style.display='none';

zoomHtml="";

}

function showZoomImg(){

var layer = document.getElementById("zoomImg");

layer.innerHTML=zoomHtml;

layer.style.display='';

}

以上模板编辑完成。

4,将以下代码保存goods_attr.php文件,保存在\admin下:

define('IN_ECS', true);

require(dirname(__FILE__) . '/includes/init.php');

require_once(ROOT_PATH . '/admin/includes/lib_goods.php');

include_once(ROOT_PATH . '/includes/cls_image.php');

if ($_REQUEST['id'])

{

    $sql        = 'SELECT goods_attr_id,goods_id,attr_value,attr_price FROM ' .$ecs->table('goods_attr').

                  ' WHERE goods_id='.$_REQUEST['id'].' ORDER BY goods_attr_id';

    $res        = $db->query($sql);

    $arr        = array();

    echo "";

    echo "";

    echo "当前属性库存:
";

    while ($row = $db->fetchRow($res))

    {

if ($row['attr_price']=="" or $row['attr_price']==0)

{

  $price="";

}else{

  $price="属性价格:".$row['attr_price'];

}

        echo "名称:".$row['attr_value']." ".$price."
";

    }

}

?>

好,大功告成!

附加说明:

1.以上针对版本:2.6.1,其他版本请自己测试增加是否适用,版本不太低的情况下,我认为适用的。

2.以上代码所涉及的图片,均在官方版本\admin\images下存在的,无须另找。

3.图中出现的库存数量,是我增加的“商品属性与库存关联”的功能(需要此功能,可联系我QQ9921841)。而以上代码不会涉及此项,可直接按照以上步骤操作,无须顾虑。

你可能感兴趣的:(php收集)