实现WordPress主题侧边栏切换功能的PHP脚本详解
作为主题的制作者,除了实现功能,展示界面,还有责任使主题灵活多变,以满足更多人不同的需求. 可能一些朋友曾为选用双栏主题 (单侧边栏) 还是三栏主题 (双侧边栏) 而烦恼过. 下面我们以 Classic 主题为例,谈谈如何在主题中方便地切换单侧边栏和双侧边栏. 最后我会提供修改后的主题. 添加管理选项后台处理 首先,我们要修改 function.php,主要的处理工作都在这个文件里面,如果主题没有这个文件,就创建一个吧. (没有 function.php 说明主题不支持 Widget,可不是一个好习惯哦,还是赶紧新建一个吧) 我的处理包括 3 大块: 获取选项,初始化,标签页操作界面. 这里只创建一个公告栏,包括两个选项 (是否显示公告栏和公告栏内容). 如果要添加更多选项,也只需要代码中 3 个 TODO 的位置上追加一些代码而已. 当然,你还需要改一下选项名称,将 Classic 和 classic 全部之换掉./ -- 获取选项组 -- / function getOptions() { // 在数据库中获取选项组 $options = get_option('classic_options'); // 如果数据库中不存在该选项组,设定这些选项的默认值,并将它们插入数据库 if (!is_array($options)) { $options['notice'] = false; $options['notice_content'] = ''; // TODO: 在这里追加其他选项 update_option('classic_options',$options); } // 返回选项组 return $options; } / -- 初始化 -- / // 数据限制 // TODO: 在这追加其他选项的限制处理 // 更新数据 // 否则,重新获取选项组,也就是对数据进行初始化 // 在后台 Design 页面追加一个标签页,叫 Current Theme Options / -- 标签页 -- / <form action="#" method="post" enctype="multipart/form-data" name="classic_form" id="classic_form"> <table class="form-table">
|
|
<p class="submit">
<?php
}
}
/**
- 登记初始化方法
*/
add_action('admin_menu','init'));
?>
前台处理
要公告栏在首页上显示,需要修改一下 index.php,这个比较简单,只是通过一些判断语句决定东西要不要显示出来而已. 当然,你可以进行其他操作,关键是获取到选项的值,并对它们进行处理. 其实可以分为两步:
获取选项 (对每个 PHP 文件,获取一次就行了,可以在文件顶部执行) 对选项进行处理 (这里判断成立的话就将公告内容显示出来)
<?php if($options['notice'] && $options['notice_content']) : ?>
<div id="notice">
<div class="content"><?php echo($options['notice_content']); ?>