Thinkphp5.0自动生成模块及目录的方法详解
本文实例讲述了thinkphp5.0自动生成模块及目录的方法。分享给大家供大家参考,具体如下:
thinkphp5.0发布已有些时日了,据说性能方面有很大的提升,按照官方的话,thinkphp5.0版本是一个颠覆和重构版本,采用全新的架构思想,引入了很多的php新特性,优化了核心,减少了依赖,实现了真正的惰性加载,并针对api开发做了大量的优化。是时候得download一份,研究一下。今天主要讲讲其自动创建模块及目录。
thinkphp5.0自动生成模块较thinkphp3.2,确实有很大的变化。
再次,主要讨论thinkphp5.0生成模块。
准备工作
首先从官方下载thinkphp5.0,下载后文件结构如下:
只保留thinkphp目录其他的所有目录及文件一并删除(可以先转移到其他地方,以备后续使用)
现在就开始生成项目需要目录
thinkphp3.2创建目录貌似简单,但是thinkphp5.0却更加灵活。不禁想起了良才是把复杂的事情变简单;庸才是把简单的事情变复杂;蠢材是把简单的事情变得更简单,复杂的事情变得更复杂。
1.创建入口文件index.php,虽然官方强调入口文件位置,可以随意放置,但是为了便于学习,还是放在根目录下
// 应用入口文件 define('app_path', 'application/'); // 定义项目路径,和之前3.2版本没有区别 define('app_auto_build',true); //开启自动生成 define('app_debug', true);// 开启调试模式 define('module','module'); // 加载框架引导文件 require 'thinkphp/start.php'; // 执行应用 \think\app::run();
其实我个人觉得,tp官方为啥不把,程序的执行\think\app::run(); 放置在start.php 目录呢?最后,发现原来tp5.0引入了一个define('app_auto_run', true);常量,当在index.php页面定义了改常量,项目就会自动执行,不需要添加\think\app::run();
2.创建项目名与build.php文件
个人感觉thinkphp5.0做的不好的一点就是上面定义的项目文件夹需要自己创建,究其原因,因为里面要放置项目创建配置文件build.php。但是为啥tp官方不把build.php放置在根目录下呢?然后自动生成application文件夹呢?在这一点我觉得tp3.2做的就比5.0好。
现在来讨论一下build.php,官方默认的bulid.php内容如下,现在来讨论一下
return [ // 生成运行时目录 '__dir__' => ['runtime/cache', 'runtime/log', 'runtime/temp', 'runtime/template'], '__file__' => ['common.php'], // 定义index模块的自动生成 'index' => [ '__file__' => ['common.php'], '__dir__' => ['behavior', 'controller', 'model', 'view'], 'controller' => ['index', 'test', 'usertype'], 'model' => [], 'view' => ['index/index'], ], // 。。。 其他更多的模块定义 ];
可以给每个模块定义需要自动生成的文件和目录,以及mvc类。
__dir__ 表示生成目录(支持多级目录)
__file__ 表示生成文件(不定义默认会生成 config.php 文件)
controller 表示生成controller类
model表示生成model类
view表示生成html文件(支持子目录)
自动生成以app_path 为起始目录, __dir__ 和 __file__ 表示需要自动创建目录和文件,其他的则表示为模块自动生成。
模块的自动生成则以 app_path.'模块名/' 为起始目录。
最后直接运行index.php文件即可。
更多关于thinkphp相关内容感兴趣的读者可查看本站专题:《thinkphp入门教程》、《thinkphp模板操作技巧总结》、《thinkphp常用方法总结》、《codeigniter入门教程》、《ci(codeigniter)框架进阶教程》、《zend framework框架入门教程》、《smarty模板入门基础教程》及《php模板技术总结》。
希望本文所述对大家基于thinkphp框架的php程序设计有所帮助。
上一篇: Java实现复杂的进制转换器功能示例
下一篇: shell特殊变量(3)