更优雅的处理ZBlogPHP主题的模板文件备注问题

模板文件备注,是开发者一开始没有关注,到后来又被各种坑的问题。

模板设定,是建站系统中常见的设定;开发者,可以开发编写不同的模板文件,在网站的文章/分类/列表等类型中去选择模板,实现相对动态的页面效果。

不谈历史,反正我们是被系统直接读取所有PHP文件坑惨了的人。被这个问题烦恼后,我在群里闹腾了一段时间,在YT提供的正则帮助下,为模板文件中加入了类型/名称。需求最后到了ZBP的开发四人组(bang)手中,只是添加了模板中名称注释,粗暴简陋,还是会让用户在使用时,错误的选择到不适合当前类型的模板。

在这之后,考虑在模板文件中频繁的读取正则备注,会增加服务器性能压力的情况,改为使用JSON配置的方式,为模板文件添加注释。

有了这个设定,那就需要设定一些规范的规则,因为JSON相对严格的数据模式;

{
    "id": "os_mylog",
    "templates": [
        {
            "filename": "index",
            "type": "list",
            "name": "列表自动模板"
        },
        {
            "filename": "single",
            "type": "single",
            "name": "文章/单页自动模板"
        },
        {
            "filename": "page-archive",
            "type": "page",
            "name": "文章归档页面"
        },
        {
            "filename": "page-link",
            "type": "page",
            "name": "友情链接页面"
        },
        {
            "filename": "page-tag",
            "type": "page",
            "name": "标签云页面"
        }
    ]
}

虽然在后面的读取操作中,id并没有使用,但考虑到冗余问题,暂时先加入id的设定。

templates是一个模板文件数组,其中每一个对象代表了一个可用的模板设定。

filename字段为文件名,*不加.php;

type字段为类型,用于区分不同位置;

name字段为模板名称描述。

关于type类型的设定:

all:全部类型可用;

single:文章或单页中可用;

list:所有列表类型可用,分类/标签/日期/作者页等;

其余类型设置与系统设定相同

添加完模板设定以后,我们还需要处理这个设定;

【处理流程】

1、尝试读取JSON文件,转为对象数据;

2、判断当前编辑的类型,匹配显示对应内容;

3、组成新的html,通过JS语句,替换掉原先的模板下来框选择内容;

这些处理,我们就单独阐述方法了,我将这个php放出来,在include.php中引用这个文件即可(当然,你要替换掉我的模板id前缀,避免变量名污染)。

在include.php中,我们在ActivePlugin_xxxxx函数中,接入接口;

Add_Filter_Plugin('Filter_Plugin_Edit_Response3','os_mylog_OutputTemplateSelect');
Add_Filter_Plugin('Filter_Plugin_Category_Edit_Response','os_mylog_OutputTemplateSelect');
Add_Filter_Plugin('Filter_Plugin_Tag_Edit_Response','os_mylog_OutputTemplateSelect');
Add_Filter_Plugin('Filter_Plugin_Member_Edit_Response','os_mylog_OutputTemplateSelect');

 

JSON需要严格编写,如果自己不能确定是否符合规范,可以在www.bejson.com这个网站中验证。


模板PHPZBlog
立即下载templat.php下载