7.21 杭州源创会火热报名中,一起来看看移动开发如何紧跟浪潮?
Watch Star Fork

IT大叔 / TolowanPHPGPL-2.0

加入码云
与超过 300 万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
基于phalcon开发的内容管理系统
IT大叔 最后提交于 更新 README.md
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README.md 4.54 KB

欢迎使用Tolowan


是基于Phalcon开发的内容管理系统。 特性:

  • 继承Phalcon框架全功能
  • 多网站支持,异站点用户文件、同网站私有/共有网站隔离
  • 强大的个性化环境,每个用户可以对网站内容和表现形式进行个性化设置
  • 基于用户角色、模块、角色的权限控制系统,当然,您也可以通过回调函数进行更精细控制
  • 提供的站内搜索系统原生支持全文搜索。
  • 使用volt编写主题模板,类twig语法,单比twig更高效
  • Tolowan提供的实体管理、字段管理、表单管理、模型管理等机制,可以大大缩减二次开发的难度和所需时间

安装部署教程

注:其中上文中siteroot为程序目录所在地址,加入QQ交流群:574199144


特性

实体(siteroot/Modules/Entity)

是具有相同功能的对象,在Tolowan中内置了三种实体类型:

  • 基于数据库模型的常规实体
  • 基于配置的配置实体
  • 基于配置列表的配置列表实体

例如,原生模块中,node、comment、user等模块是基于数据库模型的常规实体的实体对象;config是基于配置实体的实体对象;区域(region)、菜单(menu)是基于配置列表实体的实体对象。

不同的实体类型,决定了实体的保存、读取方式,但是所有实体都拥有统一的API,而定义实体,我们只需要完成实体声明数组文件和集成相应的基本实体模型即可,而实体的增、改、删、读等常规操作并不需要重新编写。

下面以node模块中的node实体为例:

  1. 在模块配置目录定义实体声明文件(siteroot/Modules/Node/config/entitys.php)
  2. 建立实体管理模型(集成基础实体管理模型类):siteroot/Modules/Node/Entity/NodeManager.php
  3. 建立实体模型(集成基础实体模型类):siteroot/Modules/Node/Entity/Node.php

2、3步的类文件可以随意在实体声明文件中制定

接下来就可以使用 adminEntity* 系列路由进行相关管理操作,当然你也可以替换/禁用这些默认操作(在此不详述)

字段

字段系统可以算是实体系统的一部分,通过它我们可以灵活的对实体进行无限制的模型扩充和灵活访问。

依旧以node实体进行操作示例:

$nodeEntity = $this->entityManager->get('node');//获取node实体

$node = $nodeEntity->findFirst(5, true);//获取ID为5的文章

$nodeUser = $node->uid->user //获取文章作者的user实体

$node -> delete(); //删除文章和相关所有字段

$nodeUser->delete(); //删除文章作者

配置(siteroot/Core/Config)

Tolowan直接以数组保存配置信息,当然使用前您需要通过命名空间引入该文件

Config::get('config') //获取config配置

Config::set('config',array())//设置配置内容

模块和主题下config目录为其配置目录,我们可以通过Config::cache()来获取某个配置的合集

Config::cache('entitys'); //合并所有已启用模块、主题config目录下entitys.php文件内容,这个合并操作在您清除配置缓存前只会进行一次


表单

Tolowan直接通过数组来声明表单,我们也可以把数组保存在配置文件中,通过配置名来生成表单。

例如:siteroot/Modules/Search/config/searchForm.php 是声明的搜索表单,配置名为:search.searchForm (模块名+文件名),在模板中我们可以这么使用。

{{ form.create('search.searchForm') }} //在模板中就可以直接生成基于bootstarp的表单html(当然也可以替换成自己的模板,此处不详谈)

模型

Tolowan中,你可以通过数组的方式来构建查询,简单距离:

 <?php
$query = array(
    'from' => 'node',
    'andWhere' => array(
        array(
            'conditions' => 'node.id < :id:',
            'bind' => array('id' => 50),
        ),
    ),
    'limit' => 15,
    'page' => 1,
    'paginator' => true,
);
Core\Db\Query::find($query);

上面的含义:查询node表中id字段值小于50的数据,且采用分页查询,每页获取15条记录,获取第一页数据

项目点评 ( 7 )

你可以在登录后,发表评论

11_float_left_people 11_float_left_close