一般来说,一个模板都会包含以下几个部分:
images文件夹:存放模板所需图片。 echo_log.php:显示日志内容。 footer.php:页面底部。 header.php:页面头部。 log_list.php:显示日志列表内容。 main.css:模板的css文件。 module.php:模板公共代码,包含侧边widgets、评论、引用、编辑等,该文件是模板最核心的模块。 page.php:自定义的页面内容的模板。 preview.jpg:在后台模板选择界面显示的模板预览图,300×225 jpg格式。 side.php:模板侧边栏文件,如制作单栏模板则该文件不是必须的。 t.php:显示emlog系统自带的微博(碎语)内容。 404.php:自定义404页面未找到时的报错页面 在一般的emlog模板开发中,以上提及的部分中echo_log.php、log_list.php、module.php、page.php、t.php、header.php以及preview.jpg是不可或缺的,一旦缺省,模板将无法运行。此外的side.php、footer.php、main.css、images文件夹等,只需要对模板代码做小部分更改,那么它们都是可以改名、移动、甚至删除的。
公共代码分析
通过预览整个模板中的各个文件,你会发现以下代码同时存在于多个文件中,这些代码分别有以下用途:if(!defined('EMLOG_ROOT')) {exit('error!');} 此行代码存在于模板目录下的每个php文件起始部分(事实上为了安全起见,该行代码也在admin目录下的几乎所有php文件起始部分存在),其作用是防止代码所在的php脚本被直接访问执行。 require_once View::getView('side'); require_once View::getView('footer'); 这两行代码存在于log_list.php、echo_log.php、page.php、t.php里面,其作用是调用模板文件夹下的side.php和footer.php的代码到当前文件的当前位置。View是emlog的模板视图控制器,View::getView('文件名','文件后缀')将返回当前模板安装路径下对应的文件。getView函数的第二个参数为缺省参数,在不传入值的情况下,将默认作为.php文件后缀返回文件路径。
$curpage:当前页面表示,常用判断tag如下: $curpage== CURPAGE_HOME:首页 $curpage == CURPAGE_TW:碎语页 $curpage == CURPAGE_LOG:日志、page页 ROLE:当前访问者身份 ROLE == 'admin':管理员 ROLE == 'writer':联合撰写人 ROLE == 'vistor':未登录用户
通用代码
<?php if(!defined('EMLOG_ROOT')) {exit('error!');} ?>存在每个php文件头部,防止非法访问 <?php include getViews('XXXX');; ?>: 调用当前模板目录下XXXX.php文件 <?php echo EMLOG_VERSION;?>:显示当前emlog版本 <?php echo TEMPLATE_URL; ?>: 显示模板文件路径 <?php echo BLOG_URL; ?>: 显示博客Url <?php echo $blogtitle; ?>: 显示博客标题(会根据当前页面变化) <?php echo $blogname; ?>: 显示博客名称 <?php echo $bloginfo; ?>:显示博客描述 <?php echo $icp; ?>:显示备案号 <?php endforeach; ?>: 循环结束,需和<?php foreach(xxxx): ?>配对 <?php endif;?>:结束if标签,需和<?php if(xxxx): ?>配对
header头部
<?php /* Template Name:(模板名称 ) Description:(模板描述 ) Author:(模板作者 ) Author Url:(作者主页 ) Sidebar Amount:1(侧边栏数目,最大4 ) */ if(!defined('EMLOG_ROOT')) {exit('error!');} require_once View::getView('module'); ?>
每个php文件的头部,防止非法访问
<?php /* * 注释位置信息 */ if(!defined('EMLOG_ROOT')) {exit('error!');} ?>
以下为通用标签
<?php echo $blogtitle; ?> 标题 <?php echo $site_key; ?>关键字 <?php echo $description; ?>副标题(描叙) <?php echo BLOG_URL; ?>网站地址(路径) <?php echo TEMPLATE_URL; ?>模板地址(路径) <?php doAction('index_head'); ?>头部插件挂载点(用在<head>标签之间,如加载JS,css等) <?php echo $blogname; ?>博客名字(使用带网站连接方法如:<a href="<?php echo BLOG_URL; ?>"><?php echo $blogname; ?></a>) <?php echo $bloginfo; ?>博客副标题 <?php echo BLOG_URL.Option::get('topimg'); ?>头部图片
使用方法:
<img src="<?php echo BLOG_URL.Option::get('topimg'); ?>" height="134" width="960" />
首页连接class选取
<?php echo $curpage == CURPAGE_HOME ? 'current' : 'common';?>
使用方法:
<li class="<?php echo $curpage == CURPAGE_HOME ? 'current' : 'common';?>"><a href="<?php echo BLOG_URL; ?>">首页</a></li>
说明:<?php if($istwitter == 'y'):?>函数变量开始,‘Y’决定后台是否开启,开启则显示,这里为加载碎语。<?php endif;?>为函数变量结束
<?php if($istwitter == 'y'):?>
<li class="<?php echo $curpage == CURPAGE_TW ? 'current' : 'common';?>"><a href="<?php echo BLOG_URL; ?>t/"> <?php echo Option::get('twnavi');?></a></li> <?php endif;?>
下为header.php头部常用标签
<?php foreach ($navibar as $key => $val): if ($val['hide'] == 'y'){continue;} if (empty($val['url'])){$val['url'] = Url::log($key);} ?>开始导航循环 <li class="<?php echo isset($logid) && $key == $logid ? 'current' : 'common';?>"><a href="<?php echo $val['url']; ?>" target="<?php echo $val['is_blank']; ?>"><?php echo $val['title']; ?></a></li> <?php endforeach;?>导航循环结束 <?php doAction('navbar', '左标签', '右标签'); ?>插件挂载点,用于导航栏,左右为html标签,用以控制样式,可为空(如:<?php doAction('navbar', '<li class="common">', '</li>'); ?>) <?php if(ROLE == 'admin' || ROLE == 'writer'): ?> 判断是否登陆(登陆则显示下面内容) <li class="common"><a href="<?php echo BLOG_URL; ?>admin/write_log.php">写日志</a></li> <li class="common"><a href="<?php echo BLOG_URL; ?>admin/">管理中心</a></li> <li class="common"><a href="<?php echo BLOG_URL; ?>admin/?action=logout">退出</a></li> <?php else: ?>(判断如果没有登陆则显示下面内容) <li class="common"><a href="<?php echo BLOG_URL; ?>admin/">登录</a></li> <?php endif; ?>(判断结束)
footer.php
<?php echo Option::EMLOG_VERSION;?>程序版本号 <?php echo $icp; ?>显示备案号 <?php doAction('index_footer'); ?>底部插件挂载点(用于统计代码等)
log_list.php
<?php doAction('index_loglist_top'); ?>插件挂载点,存在于首页日志列表顶部(用于公告等) <?php foreach($logs as $value): ?>开始循环输出日志列表 下面所有标签仅存在于<?php foreach($logs as $value): ?>和<?php endforeach; ?>之间 <?php topflg($value['top']); ?>置顶标志,函数存在于module.php <?php echo $value['log_title']; ?>显示日志标题 <?php echo $value['log_url']; ?>显示日志标题到正文连接 以上3个标签使用方法:<?php topflg($value['top']); ?><a href="<?php echo $value['log_url']; ?>"><?php echo $value['log_title']; ?></a> <?php blog_author($value['author']); ?> 作者,函数存在于module.php <?php echo gmdate('Y-n-j G:i l', $value['date']); ?>发布时间,格式是2010-12-11 19:05 30,格式可自行修改 <?php blog_sort($value['logid']); ?>分类,该函数存在于module.php <?php editflg($value['logid'],$value['author']); ?>显示编辑链接,函数存在于module.php <?php echo $value['log_description']; ?>显示日志摘要 <?php blog_att($value['logid']); ?>显示日志附件(图片附件不显示),函数存在于module.php <?php blog_tag($value['logid']); ?>显示日志标签,函数存在于module.php <?php echo $value['comnum']; ?>评论数,使用方法<a href="<?php echo $value['log_url']; ?>#comments">评论(<?php echo $value['comnum']; ?>)</a> <?php echo $value['tbcount']; ?>引用数,使用方法<a href="<?php echo $value['log_url']; ?>#tb">引用(<?php echo $value['tbcount']; ?>)</a> <?php echo $value['views']; ?>浏览数,使用方法<a href="<?php echo $value['log_url']; ?>">浏览(<?php echo $value['views']; ?>)</a> 以上仅存在于<?php foreach($logs as $value): ?>和<?php endforeach; ?>之间 <?php endforeach; ?>循环输出日志列表结束 <?php echo $page_url;?>显示分页 <?php include View::getView('side'); ?>调用边栏 <?php include View::getView('footer'); ?>调用底部 也可以写成 <?php include View::getView('side'); include View::getView('footer'); ?>
上为 log_list.php 首页日志列表部分常用标签
echo_log.php
下为echo_log.php 阅读日志页面(内容页)常用标签
<?php echo $log_title; ?>页面名字 <?php echo $log_content; ?>内容 <?php blog_att($logid); ?>附件 <?php blog_comments($comments); ?>显示评论 <?php blog_comments_post($logid,$ckname,$ckmail,$ckurl,$verifyCode,$allow_remark); ?>加载评论
下为 page.php加载独立页面模板实例
<?php if($log_title =="标签" || $log_title =="标签云"):?> <?php include View::getView('tags');?> <?php elseif($log_title =="链接列表" || $log_title =="友情链接"):?> <?php include View::getView('links');?> <?php elseif($log_title =="读者排行" || $log_title =="读者墙"):?> <?php include View::getView('readers');?> <?php elseif($log_title =="文章归档" || $log_title =="文章存档"):?> <?php include View::getView('archives');?> <?php elseif($log_title =="相关服务"):?> <?php include View::getView('service');?> <?php elseif($log_title =="模版开发" || $log_title =="Emlog模版开发"):?> <?php include View::getView('tpl');?> <?php elseif($log_title =="留言板"):?> <?php include View::getView('contact');?> <?php elseif($log_title =="点赞墙" || $log_title =="点赞榜"):?> <?php include View::getView('likes');?> <?php elseif($log_title =="7天热门文章" || $log_title =="7天热门文章排行"):?> <?php include View::getView('week');?> <?php elseif($log_title =="30天热门文章" || $log_title =="30天热门文章"):?> <?php include View::getView('month');?> <?php elseif($log_title =="30天热门评论" || $log_title =="30天热门评论排行"):?> <?php include View::getView('comnum');?> <?php if ($allow_remark == 'y'){blog_comments($comments,$params);blog_comments_post($logid,$ckname,$ckmail,$ckurl,$verifyCode,$allow_remark);} ?>
根据是否允许评论显示评论和评论表单,函数存在于module.php
t.php
<?php if(ROLE == 'admin' || ROLE == 'writer'): ?>判断是否登陆,登陆显示下面内容 <a href="<?php echo BLOG_URL . 'admin/twitter.php' ?>">发布碎语</a> <?php endif; ?>判断结束 <?php foreach($tws as $val): $author = $user_cache[$val['author']]['name']; $avatar = empty($user_cache[$val['author']]['avatar']) ? BLOG_URL . 'admin/views/images/avatar.jpg' : BLOG_URL . $user_cache[$val['author']]['avatar']; $tid = (int)$val['id']; ?> 开始循环输出碎语,下面为默认模板代码(循环的是<li>标签里的内容) <li class="li"> <div class="main_img"><img src="<?php echo $avatar; ?>" width="32px" height="32px" /></div> <p class="post1"><span><?php echo $author; ?></span><br /><?php echo $val['t'];?></p> <div class="clear"></div> <div class="bttome"> <p class="post"><a href="javascript:loadr('<?php echo DYNAMIC_BLOGURL; ?>?action=getr&tid=<?php echo $tid;?>','<?php echo $tid;?>');">回复(<span id="rn_<?php echo $tid;?>"><?php echo $val['replynum'];?></span>)</a></p> <p class="time"><?php echo $val['date'];?> </p> </div> <div class="clear"></div> <ul id="r_<?php echo $tid;?>" class="r"></ul> <div class="huifu" id="rp_<?php echo $tid;?>"> <textarea id="rtext_<?php echo $tid; ?>"></textarea> <div class="tbutton"> <div class="tinfo" style="display:<?php if(ROLE == 'admin' || ROLE == 'writer'){echo 'none';}?>"> 昵称:<input type="text" id="rname_<?php echo $tid; ?>" value="" /> <span style="display:<?php if($reply_code == 'n'){echo 'none';}?>">验证码:<input type="text" id="rcode_<?php echo $tid; ?>" value="" /><?php echo $rcode; ?></span> </div> <input class="button_p" type="button" onclick="reply('<?php echo DYNAMIC_BLOGURL; ?>index.php?action=reply',<?php echo $tid;?>);" value="回复" /> <div class="msg"><span id="rmsg_<?php echo $tid; ?>" style="color:#FF0000"></span></div> </div> </div> </li> <?php endforeach;?>循环输出碎语结束
如上代码说明:
<?php echo $avatar; ?>显示作者头像,使用方法: <img src="<?php echo $avatar; ?>" width="32px" height="32px" />这里设置了图片的高宽为32象素 <?php echo $author; ?>显示碎语发布者 <?php echo $val['t'];?>显示碎语内容 <a href="javascript:loadr('<?php echo DYNAMIC_BLOGURL; ?>?action=getr&tid=<?php echo $tid;?>','<?php echo $tid;?>');">回复(<span id="rn_<?php echo $tid;?>"><?php echo $val['replynum'];?></span>)</a>回复碎语连接使用方法 <?php echo $val['date'];?>发布碎语时间 <?php echo $tid;?>碎语ID数
使用方法
<ul id="r_<?php echo $tid;?>" class="r"></ul> 这里参考了官方模板 举例:如碎语ID为3(发布的第3条碎语),原代码显示结果为 <ul id="r_3" class="r"></ul> <?php echo $pageurl;?> 显示碎语分页 <?php echo $twnum; ?> 显示碎语数目
上为 t.php 碎语部分常用标签
side.php
<?php $widgets = !empty($options_cache['widgets1']) ? unserialize($options_cache['widgets1']) : array(); ?> 该页面要加载的widgets,中间红色1为数字,不超过header.php里设置的侧边栏数目 <?php doAction('diff_side'); ?> 插件挂载点 <?php foreach ($widgets as $val) { $widget_title = @unserialize($options_cache['widget_title']); $custom_widget = @unserialize($options_cache['custom_widget']); if(strpos($val, 'custom_wg_') === 0) { $callback = 'widget_custom_text'; if(function_exists($callback)) { call_user_func($callback, htmlspecialchars($custom_widget[$val]['title']), $custom_widget[$val]['content']); } }else{ $callback = 'widget_'.$val; if(function_exists($callback)) { preg_match("/^.*\s\((.*)\)/", $widget_title[$val], $matchs); $wgTitle = isset($matchs[1]) ? $matchs[1] : $widget_title[$val]; call_user_func($callback, htmlspecialchars($wgTitle)); } } } ?>
上这一长串用于显示widgets
<a href="<?php echo BLOG_URL; ?>rss.php" title="RSS订阅"> <img src="<?php echo TEMPLATE_URL; ?>images/rss.gif" alt="订阅Rss"/></a>
上为RSS 订阅使用方法
module.php
function widget_xxxx($title)显示widgets函数,如widget_blogger($title)显示博主信息
发表评论