自己设计一套Zencart模板吧:怎么开始?

3,349次阅读
2 条评论

共计 5720 个字符,预计需要花费 15 分钟才能阅读完成。

1. 首先在你的模板目录下,建立一个新的模板,例如:\includes\templates\mytemplate\
复制\includes\templates\template_default下的所有目录和文件到新的目录mytemplate中。

2. 用文本编辑器修改\includes\templates\mytemplate\template_info.php,修改其中的名称、版本、作者等内容。

3. 在后台Tool->Template Selection中选择使用新建的模板,并在Layout Boxes Controller中开启一些如categories等常用的边框模块。

4. 获取网站模板的图片和CSS文件
用整站下载软件实现,例如Teleport Pro,下载全站的所有图形和CSS文件,要保留原站的文件结构。
图片通常都在/images目录下,将下载到的/images下的图形文件都复制到zen cart的/images目录下。

5. 获取网站模板的按钮
也可以用Teleport Pro下载所有按钮,Zen Cart的按钮图片

在/includes/languages/english/images/buttons目录下。
将下载的按钮保存到zen cart的按钮目录/includes/templates/mytemplate/buttons/english/ 和

/includes/templates/mytemplate/buttons/schinese/ 中,在schinese目录中的按钮,可以自己用图像

处理软件转换成中文。

6. 获取网站模板的CSS文件。
ZenCart的stylesheet.css文件在\includes\templates\templateName\css目录下。仿制网站的

stylesheet.css文件具体路径在查看页面源代码时能看到。
打开获得的stylesheet.css文件,剪贴到/includes/templates/mytemplate/css/stylesheet.css文件中

,追加在原来的css文件后,不要覆盖原有的内容。

7. 打开需要复制的zen cart网站,查看源代码。(有些网站不允许你查看源代码,要一些技巧,这里就

不详细讨论这个问题了)

8. 在源代码中复制
<!– header //–> 到 <!– header_eof //–> 之间的内容作为

\includes\templates\mytemplate\common\tpl_header.php,删除该文件内原来的内容。

<!– footer //–> 到 <!– footer_eof //–> 之间的内容作为

\includes\templates\mytemplate\common\tpl_footer.php,删除该文件内原来的内容。

(有些模板把边框部分的显示也放到header.php中,那么你需要找出属于边框的部分并删除)

9. 现在,整个网站的外观已经基本出来了。需要替换上面的这两个文件内的链接,这里是模板转换的关

键。根据下面的模式替换,第一行是需要替换的类似链接,第二行是正确的代码:

http://127.0.0.1/zencart/index.php
<?php echo zen_href_link(FILENAME_DEFAULT); ?>

http://127.0.0.1/zencart/index.php?main_page=account
<?php echo zen_href_link(FILENAME_ACCOUNT, ”, ‘SSL’); ?>

http://127.0.0.1/zencart/index.php?main_page=shopping_cart
<?php echo zen_href_link(FILENAME_SHOPPING_CART, ”, ‘NONSSL’); ?>

http://127.0.0.1/zencart/index.php?main_page=checkout_shipping
<?php echo zen_href_link(FILENAME_CHECKOUT_SHIPPING, ”, ‘SSL’); ?>

http://127.0.0.1/zencart/index.php?main_page=shippinginfo
<?php echo zen_href_link(FILENAME_SHIPPING); ?>

http://127.0.0.1/zencart/index.php?main_page=advanced_search
<?php echo zen_href_link(FILENAME_ADVANCED_SEARCH); ?>

http://127.0.0.1/zencart/index.php?main_page=products_new
<?php echo zen_href_link(FILENAME_PRODUCTS_NEW); ?>

http://127.0.0.1/zencart/index.php?main_page=specials
<?php echo zen_href_link(FILENAME_SPECIALS); ?>

http://127.0.0.1/zencart/index.php?main_page=products_all
<?php echo zen_href_link(FILENAME_PRODUCTS_ALL); ?>

http://127.0.0.1/zencart/index.php?main_page=contact_us
<?php echo zen_href_link(FILENAME_CONTACT_US); ?>

还有一些必须的代码包括:

用户登录、登出的代码:
<?php if ($_SESSION[‘customer_id’]) { ?>
<a href=”<?php echo zen_href_link(FILENAME_LOGOFF, ”, ‘SSL’); ?>”><?php echo

HEADER_TITLE_LOGOFF; ?></a>&amp;nbsp;|&amp;nbsp;
<a href=”<?php echo zen_href_link(FILENAME_ACCOUNT, ”, ‘SSL’); ?>”><?php echo

HEADER_TITLE_MY_ACCOUNT; ?></a>
<?php
} else {
if (STORE_STATUS == ‘0’) {
?>
<a href=”<?php echo zen_href_link(FILENAME_LOGIN, ”, ‘SSL’); ?>”><?php echo

HEADER_TITLE_LOGIN; ?></a>
<?php } } ?>
货币选择方框的代码:
<?php
if (isset($currencies) && is_object($currencies)) {
reset($currencies->currencies);
$currencies_array = array();
while (list($key, $value) = each($currencies->currencies)) {
$currencies_array[] = array(‘id’ => $key, ‘text’ => $value[‘title’]);
}

$hidden_get_variables = ”;
reset($_GET);
while (list($key, $value) = each($_GET)) {
if ( ($key != ‘currency’) && ($key != zen_session_name()) && ($key != ‘x’) && ($key != ‘y’)

) {
$hidden_get_variables .= zen_draw_hidden_field($key, $value);
}
}
}
$content = zen_draw_form(‘currencies’, zen_href_link(basename(ereg_replace(‘.php’,”,

$PHP_SELF)), ”, $request_type, false), ‘get’);
$content .= zen_draw_pull_down_menu(‘currency’, $currencies_array, $_SESSION[‘currency’],

‘onchange=”this.form.submit();” style=”width: 100%”‘) . $hidden_get_variables .

zen_hide_session_id();
$content .= ‘</form>’;

echo $content;
?>
语言选择的代码:
<?php
if (!isset($lng) || (isset($lng) && !is_object($lng))) {
$lng = new language;
}
$lng_cnt = 0;
while (list($key, $value) = each($lng->catalog_languages)) {
$content .= ‘<a href=”‘ . zen_href_link($_GET[‘main_page’], zen_get_all_get_params(array

(‘language’, ‘currency’)) . ‘language=’ . $key, $request_type) . ‘”>’ . zen_image

(DIR_WS_LANGUAGES . $value[‘directory’] . ‘/images/’ . $value[‘image’], $value[‘name’]) .

‘</a>&amp;nbsp;&amp;nbsp;’;
$lng_cnt ++;
if ($lng_cnt >= MAX_LANGUAGE_FLAGS_COLUMNS) {
$lng_cnt = 0;
$content .= ‘<br />’;
}
}
echo $content;
?>
经过以上的替换,tpl_header.php和tpl_footer.php中所有的外部链接都应该替换为你自己的链接了。
10. 下一步,将tpl_header.php和tpl_footer.php这两个文件中的文字,替换为PHP代码,以支持多语言

。如果你只用单一语言,直接修改为你需要的文字即可。例如,
类似 “创建帐号” 改为 <?php echo HEADER_TITLE_CREATE_ACCOUNT; ?>
类似 “商品分类” 改为 <?php echo HEADER_TITLE_CATALOG; ?>
类似 “登出” 改为 <?php echo HEADER_TITLE_LOGOFF; ?>
类似 “我的帐号” 改为 <?php echo HEADER_TITLE_MY_ACCOUNT; ?>
类似 “登录” 改为 <?php echo HEADER_TITLE_LOGIN; ?>

类似 “购物车中的货品” 改为 <?php echo HEADER_TITLE_CART_CONTENTS; ?>
类似 “结帐” 改为 <?php echo HEADER_TITLE_CHECKOUT; ?>

类似“搜索”改为 <?php echo BOX_HEADING_SEARCH; ?>
类似“高级搜索”改为 <?php echo BOX_SEARCH_ADVANCED_SEARCH; ?>

类似 “特价商品” 改为 <?php echo CATEGORIES_BOX_HEADING_SPECIALS; ?>
类似 “新进商品” 改为 <?php echo CATEGORIES_BOX_HEADING_WHATS_NEW; ?>
类似 “推荐商品” 改为 <?php echo CATEGORIES_BOX_HEADING_FEATURED_PRODUCTS; ?>
类似 “所有商品” 改为 <?php echo CATEGORIES_BOX_HEADING_PRODUCTS_ALL; ?>

类似 “联系我们” 改为 <?php echo BOX_INFORMATION_CONTACT; ?>
类似 “货币” 改为 <?php echo BOX_HEADING_CURRENCIES; ?>
类似 “语言” 改为 <?php echo BOX_HEADING_LANGUAGES; ?>
还有一些可能用到的代码:

<?php echo TEXT_YOUR_IP_ADDRESS . ‘ ‘ . $_SERVER[‘REMOTE_ADDR’]; ?>
<?php echo FOOTER_TEXT_BODY; ?>
<div>Parse Time: <?php echo $parse_time; ?> – Number of Queries: <?php echo $db-

>queryCount(); ?> – Query Time: <?php echo $db->queryTime(); ?></div>
经过以上的十步操作,基本形成了网站的外观,下面要调整边框的模板了。待续。

——————————————————————————-

补充:sideboxes里的模块随意插入到网页任意位置方法

参考search_header.php的做法:

require($template->get_template_dir($column_box_default, DIR_WS_TEMPLATE,

$current_page_base,’common’) . ‘/’ . $column_box_default);

改为
require($template->get_template_dir (‘tpl_box_你自定义的文件名.php’,DIR_WS_TEMPLATE,

$current_page_base,’common’). ‘/tpl_box_你自定义的文件名.php’);

在common目录下建立此文件名:tpl_box_你自定义的文件名.php
内容:<?php echo $content; ?>
插入模块时参考写法:<?php require(DIR_WS_MODULES . ‘sideboxes/’ . ‘search_header.php’); ?>

正文完
 0
评论(2 条评论)
2012-08-23 20:17:03 回复

你牛B,都会自己做模板,这个网站的模板你会做吗
http://www.batterygripshop.com

 Windows  Chrome  美国加利福尼亚
    2012-08-24 22:09:54 回复

    呵呵,你的这个网站不错,模板还是比较成功的。Zencart的模板现在比较多。
    希望你的生意越来越好,链接我就给你留着了。

     Windows  Firefox  美国加利福尼亚旧金山

空瓶子部落

文章搜索
推荐阅读
十七个模具典型问题,十七个解决方案!

十七个模具典型问题,十七个解决方案!

1.废料跳穴 a.冲头长度不够按冲头刃口切入凹模一个料厚加1mm更换冲头 b.凹模间隙过大割入子减少间隙或用披...
如何快速0-1搭建职级体系

如何快速0-1搭建职级体系

前期准备 明确目的和原则 确定目的:明确搭建岗位职级体系是为了支持组织战略、激励员工、规范人力资源管理,还是为...
DFMEA 与 PFMEA预防措施的不同-以装配过程为例

DFMEA 与 PFMEA预防措施的不同-以装配过程为例

在汽车制造领域中,DFMEA(设计失效模式与影响分析)和 PFMEA(过程失效模式与影响分析)都扮演着极为重要...
结构化分析解决问题,这个底层能力离不开刻意练习

结构化分析解决问题,这个底层能力离不开刻意练习

不得不承认,人生就是为了解决一个一个的问题而存在。美国一个著名的心理学家马斯洛曾提出“人类需要层次理论”,他将...
科学注塑|工艺设定的核心逻辑:掌控三大阶段,告别经验主义

科学注塑|工艺设定的核心逻辑:掌控三大阶段,告别经验主义

对注塑工艺人员而言,科学设定工艺并非依赖“手感”与“经验”,而是建立在对填充、保压、冷却三大成型阶段的深度理解...
最新文章
群晖 Let’s Encrypt 泛域名证书自动更新

群晖 Let’s Encrypt 泛域名证书自动更新

目前acme协议版本更新,开始支持泛域名(wildcard),也就是说,可以申请一个类似*.domain.co...
可以卸载TV Box 了,这款支持「绅士模式」的影视神器你值得拥有

可以卸载TV Box 了,这款支持「绅士模式」的影视神器你值得拥有

还在为找优秀片源难、广告多、平台会员太贵而烦恼?今天给大家挖到一款真正的影视宝藏工具——小猫影视! 作为开源免...
【收藏】一次性解决TV点播/直播自由

【收藏】一次性解决TV点播/直播自由

很多时候,资源就在面前,但是我们视而不见,因为长久的安逸,已经让人失去动手的兴趣。但是每次我需要挨个切换APP...
OpenWrt 存储空间扩容的两种方案

OpenWrt 存储空间扩容的两种方案

说明:当我们通过群晖 VMM 虚拟机安装 Open­Wrt 时,默认会分配一个 10GB 的存储空间,而实际情...
OpenWrt修改IP地址两种方法(直接命令修改跟后台修改)

OpenWrt修改IP地址两种方法(直接命令修改跟后台修改)

OpenWrt是什么?OpenWrt一般常见于无线路由器(软路由)第三方固件,它是一个高效、可靠、功能多的路由...
热门文章
提高过程能力指数(CP/CPK)的途径

提高过程能力指数(CP/CPK)的途径

编者按:过程能力指数(CP/CPK)想必各位质量人都耳熟能详、运用自如,质量工程师之家前期也共享过数篇关于过程...
SPC控制图的八种模式分析

SPC控制图的八种模式分析

SPC控制图有八种模式,即八种判断异常的检验准则,每一种检验准则代表一种异常现象,应用SPC控制图进行过程评估...
测量高手放大招:圆跳动测量技巧总结

测量高手放大招:圆跳动测量技巧总结

01. 前言 在五金机加工厂实际的测量工作中,经常碰到要求测量两个要素的圆跳动问题, 利用不同的测量辅件及夹具...
过程能力分析(CP&cpk)

过程能力分析(CP&cpk)

引入过程能力分析的目的? 在我们现有的管理过程中,我们经常会遇到有些具体指标总是不尽人意,存在许多需要改进的地...
新能源汽车 “两会”精神宣贯会

新能源汽车 “两会”精神宣贯会

此次和大家分享新能源汽车相关政策: [embeddoc url=”https://www.ctro...
最新评论
多乐士 多乐士 通过摸索发现ssh拉取会报错,直接网页访问下载会报404错误,不知道原因;但是可以通过群晖CM注册表访问下载,其方法如下: Container Manager-注册表-设置-新增-注册表名称随便写,注册表URL填你的加速地址,勾选信任的SSL自我签署证书,登录信息不填-应用-使用你的地址,这是注册表会显示了,在搜索栏中输入映像名称,搜索结果在每一页的最后一个,你需要划到最后一个进行下载,实测可正常下载安装。 以上供网友参考。
多乐士 多乐士 还有一个比较简单的方法,只是需要一些外部工具。 1、讲损毁硬盘取出,装入外部移动硬盘 2、打开Diskgenius,定位到硬盘 3、格式化系统分区 4、重新插入硬盘 5、存储池->修复存储池即可
多乐士 多乐士 写的不错的文章
辞了老衲 辞了老衲 这个确实有帮助。
渋驀 渋驀 当然任何时候都可以用curl命令和crontab来实现动态更新DDNS的ip地址: 1、安装crontab之后为root用户创建文件/var/spool/cron/root 2、创建并配置ddnsupdate.sh,放到/usr/bin/文件下,文件内容(以he.net为例): Autodetect my IPv4/IPv6 address: IPV4:curl -4 "http://dyn.example.com:password@dyn.dns.he.net/nic/update?hostname=dyn.example.com" IPV6:curl -6 "http://dyn.example.com:password@dyn.dns.he.net/nic/update?hostname=dyn.example.com" 3、添加执行权限chomod +x /usr/bin/ddnsupdate.sh 4、编辑root用户的crontab:*/10 * * * * /usr/binddnsupdate.sh,每10分钟执行一次。好了,可以享受你的DDNS了
21410 21410 请问下载链接在那里?
madkylin madkylin 不错,不错,谢谢分享了,好东西啊 :lol:
feilung feilung 求方法
zengsuyi zengsuyi 应该挺不错的
zise zise 看看是怎么操作的。。 :oops: