OneThink学习笔记标签: OneThink1.0开发手册:http://document./manual_1_0.html简介 OneThink是一个开源的内容管理框架,基于最新的ThinkPHP3.2版本开发,提供更方便、更安全的WEB应用开发体验,采用了全新的架构设计和命名空间机制,融合了模块化、驱动化和插件化的设计理念于一体,开启了国内WEB应用傻瓜式开发的新潮流。
[ 主要特性 ]
OneThink只是一个内容管理框架,并不是一个真正意义的CMS,所以你不会看到很多的功能,也不要因此而抱怨,因为一切功能都来自于您的创造或者大家的分享。这才是OneThink的理念和定位。OneThink集成了一个完善的后台管理体系和前台模板标签系统,让你轻松管理数据和进行前台网站的标签式开发。 [ 主要功能 ]
利用OneThink现有的后台功能和标签库机制,你可以轻松的定制或者开发基于OneThink的网站和应用。 [ 最低系统需求 ]·PHP 5.3.0 或更高版本。 [ 系统安装 ]
应用架构及目录结构应用目录结构
静态资源目录结构
============================================================== 模板开发指南基础知识见 ThinkPHP3.2手册 视图部分 Onethink后台模板后台使用了模板继承,基础模板位于 后台公共js文件位于 后台公共css文件位于 在具体的控制器模板中,你可以通过继承重置 Onethink前台模板前台模板比较少,通常二次开发时会删除所有模板,根据设计重新组织和编写前台模板,所以这里对模板文件和目录不做介绍。 标签库OneThink定义了两个标签库Think和Article,类文件位于 Think标签库Article标签库
Article:list 标签补充说明category 属性 最好是带单引号, 如 Article:position 标签补充说明:
所以一般前台读取的时候,一般传指定的数字如 而cate 这边比较坑, 默认你传指定的45 单数字没问题, 传多个分类 45,46 这样不行的,必须带单引号 如 onethink常用标签的使用示例首页文章模型列表输出: <article:list name="article" category="2" row="3" order="update_time desc" limit="0,1" child="true">
阅读:{$article.view}
发布时间:{$article.create_time|date=‘m-d‘,###}
作者:{$article.uid|get_username}
文章标题:{$article.title}
原文链接:{:U(‘Article/detail?id=‘.$article[‘id‘])}
文章描述:{$article.description}
首页简介(单个文章)输出: {$wdjj.content|strip_tags|mb_substr=0,150,"UTF8"}
文章详情页: 标题:{$info.title} 分类列表: <volist name="category" id="cate">
<eq name="current" value="$cate[‘id‘]">
<li class="active">
<a href="{:U(‘Article/lists?category=‘.$cate[‘name‘])}">
<i class="icon-chevron-right"></i>{$cate.title}
</a>
</li>
<else/>
<li>
<a href="{:U(‘Article/lists?category=‘.$cate[‘name‘])}">
<i class="icon-chevron-right"></i>{$cate.title}
</a>
</li>
</eq>
</volist>
oneThink后台添加插件步骤详解内容管理框架:oneThink 版本:V1.1.141212 (注:v1.1也有很多版本,一不小心就下到V1.1.140202 去了,还有其他版本,建议去代码托管平台下载最新版本) 我也不偷懒,把每一步步骤都记录下来。 一、进入后台,创建插件 这里的钩子我新建了一个indexFooter,因为我只需在前台首页底部显示友情链接即可。我们把上面所有要勾的地方都勾上,至于有什么区别,大家可以自己建几个例子区分一下,生成的文件是否一样。OK!到这里 我们的友情链接插件就创建好了!点击“确定”。(这里的自定义模板什么的,通通不填,我会在下篇文章演示添加自定义模板的效果) 二、点击“安装” 即可,找到我们刚安装好的Links插件,点击“设置”,你会看到它有个默认的“是否开启随机”的选项,这里我们不管它,因为我们用不上,等下要删掉的。安装后,我们可以在左侧导航“已安装插件后台”看到我们新建的“友情链接” 三、当我们点击左侧导航的“友情链接”,你会发现报错,大概就是说的某个表不存在。是的,我们刚才只是建了插件,如果涉及到数据存储到数据库, 还需要建表。这里不直接去数据库里建,因为这样做,是很不人性化的。那我们就找到安装插件的函数,在安装插件的时候建立数据库,这样就好了。首先系统的插件全部存放在 根目录/Addons/ 文件夹下面,打开此文件夹,我们看到有个Links文件夹,这就是我们刚创建的插件,一个插件对应一个文件夹。打开Links文件夹,里面有2个文件和2个文件夹。 四、其实现在oneThink做的越来越简洁了,不懂PHP的人照样创建插件,之后你就会发现。当然,如果你有自己的想法,不想局限于官方的限制,那还是要把php学好的。 五、打开插件入口文件:LinksAddon.class.php 里面有个类 LinksAddon,先来分析一下这个文件吧 我这里把 $admin_list 数组的model 值改成links了,为了与插件对应。接下来我们在install方法里添加新建数据库的语句,这样我们在安装插件的时候,就会新建数据库了,我的代码如下: 1 public function install(){ //安装插件的方法
2 //1、添加数据表
3 $model = D();
4 $db_prefix = C(‘DB_PREFIX‘);
5 $table_name = "{$db_prefix}links";
6
7 $sql=<<<SQL
8 CREATE TABLE IF NOT EXISTS `$table_name` (
9 `id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT ‘主键‘,
10 `title` varchar(80) NOT NULL DEFAULT ‘‘ COMMENT ‘站点名称‘,
11 `link` varchar(140) NOT NULL DEFAULT ‘‘ COMMENT ‘链接地址‘,
12 `summary` varchar(255) NOT NULL DEFAULT ‘‘ COMMENT ‘站点描述‘,
13 `mailto` varchar(100) NOT NULL DEFAULT ‘‘ COMMENT ‘站长联系方式‘,
14 `sort` int(3) unsigned NOT NULL DEFAULT 0 COMMENT ‘优先级‘,
15 `nofollow` tinyint(1) unsigned NOT NULL DEFAULT 0 COMMENT ‘是否追踪‘,
16 `type` tinyint(3) unsigned NOT NULL DEFAULT 1 COMMENT ‘类型分组‘,
17 `cover_id` int(11) unsigned NOT NULL DEFAULT 0 COMMENT ‘封面图片‘,
18 `status` tinyint(2) NOT NULL DEFAULT 1 COMMENT ‘状态(0:禁用,1:正常)‘,
19 `create_time` int(11) unsigned NOT NULL DEFAULT 0 COMMENT ‘添加时间‘,
20 PRIMARY KEY (`id`)
21 ) ENGINE=MyISAM AUTO_INCREMENT=4 DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT=‘友情连接表‘;
22 SQL;
23
24 $model -> execute($sql);//执行sql语句
25
26 //2、返回true,表示插件安装成功
27 return true;
28 }
我这里省略了很多细节判断,大家自己完善。 六、既然在安装插件的时候,新建了表,我们在卸载的插件的时候就要把表给删除,不然下次安装该插件的时候就会出问题。所以我们uninstall 方法代码如下: public function uninstall(){ //卸载插件的方法
$model = D();
$db_prefix = C(‘DB_PREFIX‘);
$table_name = "{$db_prefix}links";
$sql="DROP TABLE IF EXISTS `".$table_name."`;";
$model -> execute($sql);//执行sql语句
return true;
}
好了,到这里就差不多了,保存一下LinksAddon.class.php 文件,应该可以正常显示了,我们来看看。进入插件列表,先把Links插件卸载,然后重新安装。点击左侧菜单“友情链接”,可以看到 之所以能正常显示这个列表,是因为系统有默认的模板,在\Application\Admin\View\Addons 文件夹里,有兴趣的同学可以研究一下这几个模板文件,其中这个列表的模板就是adminlist.html,那么我们要把封面、书名、描述等等这些字眼改掉,要去模板里改吗?细心的同学估计注意到了,在LinksAddon.class.php 文件 的$admin_list 数组里配置的,其他的看后面的注释就明白,这里详细说一下 list_grid 关联的数组。我们刚才新建的links数据表有id、title、link等字段,你想在这个列表显示什么字段,都可以添加。我这里代码如下: ‘list_grid‘=>array( //这里定义的是除了id序号外的表格里字段显示的表头名和模型一样支持函数和链接
‘title:网站名称‘,
‘link:链接‘,
‘summary:描述‘,
‘create_time|time_format:添加时间‘, //time_format 是一个函数,把时间格式化,其他地方想使用什么函数也可以按照这种格式书写
‘id:操作:[EDIT]|编辑,[DELETE]|删除‘
),
保存,刷新后台友情链接列表 我们点击“新增” 来增加一个友情链接吧,你会发现,只有一个书名字段。我们打开Model/LinksModel.class.php 文件,我这里分别解释一下这两个自带的数组,具体看下面代码里的注释 class LinksModel extends Model{
public $model = array(
‘title‘=>‘‘,//新增[title]、编辑[title]、删除[title]的提示
‘template_add‘=>‘‘,//自定义新增模板自定义html edit.html 会读取插件根目录的模板
‘template_edit‘=>‘‘,//自定义编辑模板html
‘search_key‘=>‘‘,// 搜索的字段名,默认是title
‘extend‘=>1, //在后台列表是否显示 “增加”、“删除” 按钮,0-不显示 1-显示
);
public $_fields = array(
‘id‘=>array(
‘name‘=>‘id‘,//字段名,与数据库的字段对应
‘title‘=>‘ID‘,//显示标题
‘type‘=>‘num‘,//字段类型:num、string、textarea、datetime、bool、select、radio、checkbox、editor、picture(封面)、file(附件)、
‘remark‘=>‘‘,// 备注,相当于配置里的tip
‘is_show‘=>3,// 1-始终显示 2-新增显示 3-编辑显示 0-不显示
‘value‘=>0,//默认值
),
ok,我最后的效果是这样的: 添加一条数据看看吧: 这里要显示具体类型、显示图片等,需要自定义adminlist.html模板了。关于自定义模板,我们下一篇文章再说。关于钩子,其实就是写一个函数从数据库读取数据,然后在前台需要的地方调用钩子就行。如果需要模板,则在钩子函数里解析模板。钩子调用格式一般: {:hook("钩子名称"),"[参数]"} 没参数就不写。直接写成这样{:hook("钩子名称")} 到此为止就是用系统默认的模板,一步一步的建立自己的插件,是不是很简单,就像填空题一样,只要按照它的规则填空,就ok了。 |
|