Thinkphp5.0自动生成模块及目录的方法详解

时间:2022-09-17 17:00:54

本文实例讲述了thinkphp5.0自动生成模块及目录的方法。分享给大家供大家参考,具体如下:

thinkphp5.0发布已有些时日了,据说性能方面有很大的提升,按照官方的话,thinkphp5.0版本是一个颠覆和重构版本,采用全新的架构思想,引入了很多的php新特性,优化了核心,减少了依赖,实现了真正的惰性加载,并针对api开发做了大量的优化。是时候得download一份,研究一下。今天主要讲讲其自动创建模块及目录。

thinkphp5.0自动生成模块较thinkphp3.2,确实有很大的变化。

再次,主要讨论thinkphp5.0生成模块。

准备工作

首先从官方下载thinkphp5.0,下载后文件结构如下:

Thinkphp5.0自动生成模块及目录的方法详解

只保留thinkphp目录其他的所有目录及文件一并删除(可以先转移到其他地方,以备后续使用)

现在就开始生成项目需要目录

thinkphp3.2创建目录貌似简单,但是thinkphp5.0却更加灵活。不禁想起了良才是把复杂的事情变简单;庸才是把简单的事情变复杂;蠢材是把简单的事情变得更简单,复杂的事情变得更复杂。

1.创建入口文件index.php,虽然官方强调入口文件位置,可以随意放置,但是为了便于学习,还是放在根目录下

?
1
2
3
4
5
6
7
8
9
// 应用入口文件
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内容如下,现在来讨论一下

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
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文件即可。

Thinkphp5.0自动生成模块及目录的方法详解

希望本文所述对大家基于thinkphp框架的php程序设计有所帮助。