Ecshop二次开发之自定义库文件和模板数据调用实例

所属分类: CMS教程 / ecshop 阅读数: 297
收藏 0 赞 0 分享

本文实例讲述了Ecshop二次开发之自定义库文件和模板数据调用方法。分享给大家供大家参考。具体方法如下:

Smarty的标签非常多,也比较繁琐,所以Ecshop使用了精简版的Smarty,其中用到的Smarty模板语法:

{$keywords} 输出模板变量
{$array.test.abc} 输出二维数组
{$lang.remark_package} 语言包$lang[remark_package]
{insert_scripts files='common.js'} 引入js文件
<!-- {foreach from=$property_group item=property} -->xxxx<!-- {/foreach} --> 循环
<!-- {if $package_goods_list} -->xxxx<!-- {/if} -->  判断
<!-- #BeginLibraryItem "/library/goods_tags.lbi" --><!-- #EndLibraryItem -->  引入goods_tags.lbi库文件,相当于PHP的include
{*内容*}  html注释,只在模板上显示,页面上会被删除掉.Ecshop二次开发的数据调用,主要动用到以下两个目录下的文件
dwt(模板文件)路径: themes\default
lbi(库文件)路径: themes\default\library
举个例子就很清楚了,是我从网上找来的,由于转载得很严重,所以不知道真正出处。
我们在themes\default\library下新建一个名为newest_comments.lbi的库文件,写入以下内容:

复制代码
代码如下:
if(!function_exists("get_new_comments")){
function get_new_comments($num)
{
$sql = 'SELECT * FROM '. $GLOBALS['ecs']->table('comment') .
' WHERE status = 1 AND parent_id = 0 and comment_type=0 '.
' ORDER BY add_time DESC';
if ($num > 0)
{
$sql .= ' LIMIT ' . $num;
}
//echo $sql;
$res = $GLOBALS['db']->getAll($sql);
$comments = array();
foreach ($res AS $idx => $row)
{
$comments[$idx]['add_time'] = $comments[$idx]['add_time'] = local_date
($GLOBALS['_CFG']['time_format'], $row['add_time']);
$comments[$idx]['user_name'] = $row['user_name'];
$comments[$idx]['content'] = $row['content'];
$comments[$idx]['id_value'] = $row['id_value'];
}
return $comments;
}
}
$this->assign('new_comments',get_new_comments(10)); // 10条最新评论
?>
<!--数据调用-最新评论开始 -->
<div class="comments">
<!--{foreach from=$new_comments item=comment}--></p> <p><div class="t_l f_l"><a href="goods.php?id={$comment.id_value}" target="_blank">
{$comment.content|truncate:15:""}</a></div>
<div class="d_r f_r">时间:{$comment.add_time}</div>
<!--{/foreach}--></div>

这样一个库文件就做好了。我们发现,库文件可以使用PHP、Smarty标签和HTML混写的写法,这无疑大大降低了我们二次开发的难度。这个库文件的作用,就是取出数据库中的10条最新评论,并且循环输出到模板。

接下来我们就要在模板中调用这个库文件,我们打开首页的模板themes\default\index.dwt(这里的dwt文件和页面都是一一对应,如商品页是goods.dwt,品牌页是brand.dwt)。我们在首页模板适当的地方加入:

复制代码
代码如下:
<!-- #BeginLibraryItem "/library/newest_comments.lbi" --> @@@这里即使修改了也没反应@@@<!-- #EndLibraryItem -->

这样就实现了自定义库文件的编写和调用。

细心的你可能会发现,在Ecshop的dwt模板文件中,调用库文件标签<– #BeginLibraryItem “/library/和<– #EndLibraryItem –>之间存在着一些和对应的lbi库文件中重复的内容。你可以把它们当作是注释,用Dreamweaver等编辑器编辑模板时候的需要看见的注释。 真正的库文件内容还需要到相应的库文件中去修改。好吧 ,就是这些,简单吧。

希望本文所述对大家的ecshop二次开发有所帮助。

更多精彩内容其他人还在看

ecshop实现针对不同支付方式对应不同价格折扣的方法

这篇文章主要介绍了ecshop实现针对不同支付方式对应不同价格折扣的方法,涉及针对Ecshop底层相关逻辑判定代码的修改操作,需要的朋友可以参考下
收藏 0 赞 0 分享

ecshop商品批量上传乱码读CSV的方式问题

ECShop后台用CSV批量上传商品数据包出现一堆乱码,问题相当严重经分析之后发现ECShop读CSV的方式弱爆了,接下来为大家详细介绍下解决方案,感兴趣的各位可以参考下哈
收藏 0 赞 0 分享

ecshop 注册送红包实现代码

有时候我们在使用ecshop过程中,一些推广优惠,这里特分享下实现代码,需要的朋友可以参考下
收藏 0 赞 0 分享

ecshop显示商品按月统计销售数量

统计商品出售总数,和半年或者三个月,一个月的出售数量。复制此函数粘贴到根目录下goods.php末尾。然后回到该文件241行给变量赋值
收藏 0 赞 0 分享

调用ecshop商品顶级分类ID我NAME的二种方法

本文总结一下ecshop 获取所在商品的顶级分类ID及NAME两种方法
收藏 0 赞 0 分享

ecshop数据库ecs_stats短时间内会变很大的解决方法

ecs_stats表是记录访问日志的,短时间内会增加很多数据库存储空间,建议清空日志表所有记录,具体操作步骤如下,大家可以参考下
收藏 0 赞 0 分享

ecshop邮件服务器设置方法

这篇文章主要介绍了ecshop邮件服务器设置方法,需要的朋友可以参考下
收藏 0 赞 0 分享

ecshop购物车消失后产品只能单件购买的解决方法(一步购物设置方法)

这篇文章主要介绍了ecshop一步购物设置方法,下面客户碰到的问题也和一步购物设置有关,这里给出解决方法
收藏 0 赞 0 分享

ecshop数据库备份和数据库恢复的步骤

这篇文章主要介绍了ecshop数据库备份和数据库恢复的步骤,需要的朋友可以参考下
收藏 0 赞 0 分享

设置ecshop的wap版本head部分首页标题的方法

如何设置ecshop的wap版本首页标题?在templates下文件有index.html,修改该文件head部分代码就可以了,不会的可以看看本文
收藏 0 赞 0 分享
查看更多