phpcms模块开发详解

更新时间:2022-05-28 20:44:16 来源:phpcms官方 作者:青锋建站
  phpcms模块方便进行扩展,以及团队协作开发,可以在原因的功能和框架之上来增加新的功能。以下是青锋建站给大家分享的phpcms模块开发的详细过程与步骤。

phpcms模块开发流程

1、创建数据库和数据表;(没有数据库操作可略过)
2、创建模块目录
3、创建模块控制器类;
4、创建模块类与模块函数;(如果只是简单的模块可以不必创建)
5、创建模板文件;
6、运行和调试。

创建phpcms模块

  phpcms v9框架中的模块,位于phpcms/modules目录中 每一个目录称之为一个模块如果要创建一个模块,只要在 phpcms/modules 目录下创建文件夹并放入你的控制器类就可以了。
例如我要开发一个叫做test的模块,那么首先在 phpcms/modules 目录下创建文件夹,并将其命名为test。test模块的标准结构通常是这样的。
创建模块
  其中classes 为模块类库包,functions 为模块函数库包, templates 为模块模板包 这里通常放置含有权限控制的控制器模板,也就是后台模板。如果您的模板有单独的前台模板,你需要在phpcms emplatesdefault下创建一个您的模块目录来放置前台模板,"default"为你的风格包名称,我们默认适用default

创建模块控制器类

  在创建模块中我们已经创建好了一个名为“test”的模块,接下来我们继续为这个模块添加两个控制器类。
  phpcms v9的控制器就是模块的类文件,位于phpcms/modules/模块/目录下面。类名成就是文件名+.php,例如一个名为mytest的控制器,那么他的命名为mytest.php即可。控制器类默认继承系统的函数库,可以直接使用。控制器类的类名称与控制器文件名必须相同。
控制器类文件包含两种形式:
1、mytest.php 控制器,前台浏览(不含权限控制)
<?php
                  defined('IN_PHPCMS') or exit('No permission resources.');
                  class mytest {
                     function __construct() {
                    }
                    public function init() {
                     $myvar = 'hello world!';
                     echo $myvar;
                     }
     public function mylist() {
                     $myvar = 'hello world!this is a example!';
                     echo $myvar;
                     }
                  }
?>
这个控制器的url访问方法前面已经介绍过了,
http://www.yourname.com/index.php?m=test&c=mytest
http://www.yourname.com/index.php?m=test&c=mytest&a=mylist
没有填写 “a” 的情况下,默认调用init方法
2、mytest_admin.php 控制器,后台管理(含权限控制)
  后台控制控制器需要加载admin模块下的admin类,并继承该类。需要注意的是因为你添加的控制器类继承了其他的类,你要小心你控制器的方法名不要和该类中的方法名一样了,否则会造成影响,具体请查看admin类中有哪些方法。
<?php
                defined('IN_PHPCMS') or exit('No permission resources.');
                pc_base::load_app_class('admin','admin',0);
                class mytest_admin extends admin {
                  public function __construct() {
                  }
                  public function init() {
                    $myvar = 'oh,i am phpcmser';
                    echo $myvar;
                  }
                }
?>

在控制器中增加模板调用

phpcms 可以实现完全的模板与程序分离,所以在我们的控制器程序中要加载模板,才可以更友好的显示出来。
1.加载前台模板
  前台模板文件在phpcms emplatesdefault模块名称 目录中,本示例也就在phpcms emplatesdefault est中
  加载模板方法如下:include template('test', 'mytest', 'default');其中 test为模块名称 mytest 为模板目录下模板名称,default为风格名称,默认不填为defalut。在上面例子中如果要给mytest.php中init方法加载一个mytest的模板,如下
  public function init() {
                     $var = 'hello world!';
                     include template('test', 'mytest', 'default');
                   }
这样我们通过url访问该方法的时候也就加载了对应的模板。
2.加载后台模板
  后台模板文件在phpcmsmodules模块名称 emplates 目录中,本示例也就在phpcmsmodules est emplates 中。加载模板方法如下:include $this->admin_tpl('mytest_admin_list');其中mytest_admin_list为phpcmsmodules est emplates中mytest_admin_list.tpl.php,注意:此处模板必须以.tpl.php 作为后缀。在上面例子中如果要给mytest_admin.php中init方法加载一个mytest_admin_list的模板,如下
 public function init() {
                    $myvar = 'oh,i am phpcmser';
                    include $this->admin_tpl('mytest_admin_list');
                  }   

创建数据库模型类

数据库模型类创建  
  数据库模型位于:phpcms/model/ 目录下。数据模型文件的命名规则建议为数据表名称+'_model.class.php'。如果在我们的创建的模块中我要使用一个数据库“test”,首先需要建立一个数据库模型文件,文件名称为'test_model.class.php'。内容如下:
<?php
   defined('IN_PHPCMS') or exit('No permission resources.');
   pc_base::load_sys_class('model', '', 0);
   class test_model extends model {
     public function __construct() {
     $this->db_config = pc_base::load_config('database');
     $this->db_setting = 'default';
     $this->table_name = 'test';
     parent::__construct();
   }
  }
 ?>
注意:
1.数据库模型类名称必须与文件名称相同;
2.$this->db_setting = 'default'为数据库配置文件中配置数据库链接池名称,默认为default,一般情况下不需要修改。
3.$this->table_name = 'test'为数据表名称
  这样我们就建立好了一个数据库模型类。在模块的控制器中使用$this->db = pc_base::load_model('test_model');来加载。
数据库模型类使用方法
<?php
   defined('IN_PHPCMS') or exit('No permission resources.');
   class mytest {
     private $db;
      function __construct() {
       $this->db = pc_base::load_model('test_model');
     }
     public function init() {
       $result = $this->db->select();
       var_dump($result);
      }
   }
 ?>
其中$this->db中所支持的方法请参照phpcms/libs/classes/model.class.php中方法。
   以上就是青锋建站给大家分享的phpcms模块开发详解,包括模块的创建,模块控制器类创建,控制器加载模板,创建模型类。青锋建站,提供专业的高品质网站制作服务,包括phpcms网站建设,SEO,网络营销,PHP网站建设

转载请注明来源网址:青锋建站-http://www.sjzphp.com/webdis/phpcms_module_908.html

电话 15632335515 | 邮箱 943703539@qq.com | QQ 943703539 | 微信 qingfengjianzhan

Copyright © 2016-2026 青锋建站 版权所有