'URL_HTML_SUFFIX'=>'html'
这个应该需要自己创建。准备工作
首先从官方下载ThinkPHP5.0,下载后文件结构如下:
只保留thinkphp目录其他的所有目录及文件一并删除(可以先转移到其他地方,以备后续使用)
现在就开始生成项目需要目录
thinkphp3.2创建目录貌似简单,但是thinkphp5.0却更加灵活。不禁想起了良才是把复杂的事情变简单;庸才是把简单的事情变复杂;蠢材是把简单的事情变得更简单,复杂的事情变得更复杂。
1.创建入口文件index.php,虽然官方强调入口文件位置,可以随意放置,但是为了便于学习,还是放在根目录下
[php] view plain copy
// 应用入口文件
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内容如下,现在来讨论一下
[php] view plain copy
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默认情况下使用url会生成全静态化地址。
如果需要将参数以动态形式展示,可以配置url_common_param属性为true即可。
举例如下:
假设我们已注册的路由是:
Route::rule('blog/:id', 'index/blog/read')执行url方法:
url('index/blog/read', ['id'=>5, 's'=>'testKeyword'])默认情况下的结果:
/blog/5/s/testKeyword.html
开启url_common_param后的结果:
/blog/5.html?s=testKeyword
总结:
开启url_common_param后的结果应该是你想要的结果,开启这个属性后,非路由中指定的参数都将以动态参数生成。而本例中id是注册在路由中的。所以id参数任然以静态形式展示。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)