目录介绍
开发一个项目的时候,通常分为前台和后台,前台一般放在index模块中,后台一般放在admin模块中。
模块内部,都遵循着MVC架构
下面对application文件夹中的文件做一些介绍;
common.php 常用的函数,都写在这个文件中
config.php 配置文件,开启什么,关闭什么,都在这设置
database.php 连接数据库时候读取的文件,比如用户名
route.php 路由文件,美化url的
tags.php 扩展框架的时候用到
![](https://i-blog.csdnimg.cn/blog_migrate/8c9a9be2dab122d6de8bc18125aa7083.webp?x-image-process=image/format,png)
![](https://i-blog.csdnimg.cn/blog_migrate/cb101c3e80d1a261e6a1c6c02d649957.webp?x-image-process=image/format,png)
favicon.ico 这个是网站图标,在标签栏显示的
index.php 网站入口文件,所有的请求都会经过这里
robots.txt 禁止搜索引擎爬取页面的设置
router.php 在没有部署网站环境的情况下,配置这个文件可以让网站运行
类的文件名以命名空间定义,并且命名空间和类库文件所在路径一致。
类的文件采用驼峰,并且首字母大写,其余文件为小写加下划线。
类名和类文件名保持一致,采用驼峰命名,首字母大写。
函数使用驼峰命名,首字母小写。
属性名采用驼峰,首字母小写
以双下划线开头的函数或方法为魔术方法。
常量以大写字母和下划线命名
表和字段必须以小写字母和下划线命名方式,不能以下划线开头。
![](http://upload-images.jianshu.io/upload_images/5273711-836574ab7e2c05e7.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000)
可以自己创建common模块,然后里面写一些其他模块会常用的控制器,或者其他模块依赖的控制器,让他们继承。
![](http://upload-images.jianshu.io/upload_images/5273711-b122725fbff5e484.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000)
惯例配置与应用配置与扩展配置
所谓应用位置,就是对app文件夹中文件都起作用的配置。
创建了配置文件后,必须要在入口文件出定义配置文件的路径,并且要将配置文件命名为config.php才可以。
通常是不允许修改TP5框架的惯例配置的,这样不安全也不规范,只要定义了应用配置,那么应用配置文件中的配置的值会代替惯例配置中相同的配置,若是没有相同的值,那么就会新添加应用配置中的值。(惯例配置不会遭到修改)
![](https://i-blog.csdnimg.cn/blog_migrate/b490cb796b41b76b9d81d7b148837121.png)
如果项目比较大,配置信息也就多,放在一个配置文件中不合适,所以就有了扩展配置。优先级是扩展配置会覆盖conf/config.php配置,会覆盖TP5惯例配置。另外,扩展配置文件夹必须叫做extra文件夹,同时TP5为了人性化,允许与conf/config.php同级创建database.php,但是,这个database.php是属于extra扩展配置的,拥有扩展配置的优先级覆盖。
场景切换配置
在惯例配置中,有'app_statues'参数,默认为空,但是可以在应用配置conf/config.php中设置该参数的值为场景名称,然后再创建该场景名称的配置文件,在里面写入想配置的参数就可以了。只要想切换场景,就修改conf/config.php这个应用配置文件中'app_status'的值即可。
![](https://i-blog.csdnimg.cn/blog_migrate/6b8ae22ec633b04ad2e3aad791ea5da6.png)
在conf/config.php中,只要调整'app_status'的值为home,那么就会调用conf/home.php中的配置。
不过,由于TP5的BUG,必须要在conf/home.php中将完整的database.php中的代码复制过来,否则,修改完一处参数后,整个应用配置只有修改后的这个参数,原来的database.php中的其他参数就默认没有了。
以上内容的配置,都是对整个应用起作用的,针对模块的单独的配置,下面会有。
模块配置与动态配置
![](https://i-blog.csdnimg.cn/blog_migrate/2d66dc502a3183b8eac5eec257e595df.png)
只要像上方那样做修改就可以了。
而动态配置,指的就是在控制器中进行配置,或者在控制器的方法中进行配置。说的再直白点,就是在类中用构造方法配合config()函数进行配置,这种配置,对整个类都有作用。若想对指定方法配置,那么就在那个方法中用config()函数进行配置就可以了。
![](https://i-blog.csdnimg.cn/blog_migrate/6aac1bdf6f468fe6ccc162c7d54b5339.png)
我上面只是在方法中没有输出config()配置罢了,不然只要访问方法,就可以看到。
环境配置
环境配置结合场景配置,先在根目录创建.env文件,然后在应用配置的config文件中利用 think\Env 这个类中的 Env::get()函数获取.env文件中的值,来对场景进行选择。这样就不用修改场景,只需要修改.env中的配置的值就可以了。
绑定入口文件
绑定入口文件之后,就可以直接加控制器和方法来访问了,如果绑定了控制器,那么只要输入方法就可以了。
通常用于接口使用,比如让第三方接入的时候,不希望第三方访问我们的index模块或者admin模块,那么就用这个绑定入口文件来解决。
另外,一旦进行了入口文件的绑定,比如我上面绑定了index,那么我也无法访问admin模块下的页面了。只能访问index模块中的页面
![](https://i-blog.csdnimg.cn/blog_migrate/da533d6a038fcf7bd11d631f8f7877bd.png)
路由
若要使用路由,那么首先要开启路由,在convention.php文件中默认开启路由。
不过,因为要用到我们的app中,所以需要将开启语句复制到conf/config.php中
![](https://i-blog.csdnimg.cn/blog_migrate/ed4c34b0eea6c639d177f20ce8b7261b.webp?x-image-process=image/format,png)
一旦设置好路由的规则后并且开启了url_route_must=true,那么访问原来的index/Index/info/id/5就会报错,只能访问news/5。所以,要想原来访问的地址也能访问,就将url_route_must=false
![](https://i-blog.csdnimg.cn/blog_migrate/8a30cc752149c9cefef919dadd34bd1d.webp?x-image-process=image/format,png)
这里输出的是news/10,因为这里之前定义了index/index/info的路由为news/:id,如果没有定义过,那么输出就是原来的路径,而不是路由的路径
![](https://i-blog.csdnimg.cn/blog_migrate/ca2ae34bc08bba8f65fef038908acdc6.webp?x-image-process=image/format,png)
请求对象的获取
![](https://i-blog.csdnimg.cn/blog_migrate/df151d6b7f990919d83a171f8e9b07a7.webp?x-image-process=image/format,png)
实际上,可以仔细参考一下这个框架的编写风格,感觉能学到不少编程思想。
由于上面返回的基本上都是关键数组,所以,如果想获取某个返回的数组中参数的值,可以直接在方法中加上参数名。
![](http://upload-images.jianshu.io/upload_images/5273711-388a27161be15b09.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000)
上面的param方法,会返回get,post,pathinfo这几个的值
![](http://upload-images.jianshu.io/upload_images/5273711-768cadb9ae0b1bbf.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000)
上图第三个参数,是用来过滤获取到的值的,之所以是用intval,是对获取到的值进行整数强制转换。
推荐自己写代码不用助手函数input,用request类那样的写法,这样代码的可读性更高,但是input还是要了解,因为每个人的代码不同。
控制器中不建议使用die函数,可以用return来结束。
![](http://upload-images.jianshu.io/upload_images/5273711-090279c7e6403951.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000)
上面用到了Config类,但是却忘记 use think/Config;
了
返回对象一般都是动态配置,因为不能保证每个控制器的返回对象都相同。
视图和模板
![](http://upload-images.jianshu.io/upload_images/5273711-274d002d6dbb85e5.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/962)
控制器中,可以使用view()函数来将与controller同一层的view模块中的与控制器同名的index文件夹中的与index()方法同名的intex.html渲染出来。这个是一个对应关系。Index控制器对应的是view/index文件夹
只要做到view文件夹路径后的文件名对应模块名就可以了,控制器中的view()方法可以指定参数。
![](http://upload-images.jianshu.io/upload_images/5273711-1afc36c2e570ed10.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000)
view('./html/index.html')函数里面传入这样的参数,代表是从入口文件进去了,而不是像view('index')这样代表view/index.html
![](http://upload-images.jianshu.io/upload_images/5273711-2161f7abf675fba9.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000)
return view('index',[
'email'=>'123456@qq.com', 'name'=>'xxx' ])
类似这样的用法,是view()函数向指定要渲染的html页面传输变量emali和变量name的值。只需要在显示的位置{$email}
或者{$name}
就可以了。
![](http://upload-images.jianshu.io/upload_images/5273711-7cbc7762b83e29a7.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000)
要渲染的页面,只要输入大写的STATAC,那么就会被下面这个view函数的第三个参数的值所替换,通俗点看就是渲染了常量。
![](http://upload-images.jianshu.io/upload_images/5273711-5775d1cc78e37c1d.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000)
不过,上面的方法还是不推荐使用,代码可读性不高。实际开发中,最好是继承think\Controller,然后,使用$this->fetch()来渲染。用法和view()一样。
![](http://upload-images.jianshu.io/upload_images/5273711-b602c2ba00a6b3ea.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000)
也可以直接使用$this->assign('a','a的值')
来给要渲染的页面上的a变量赋值。
![](http://upload-images.jianshu.io/upload_images/5273711-732a5cc3ae903994.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000)
当view文件夹中没有任何要渲染的模板的时候,就用到了下面这个函数
同时也比较有用的一个方法是$this->display('只显示我这个字符串内容'),这是只传入一个参数的时候。
![](http://upload-images.jianshu.io/upload_images/5273711-bfc65ca6ad77dc49.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/794)
在渲染页面的时候,TP5框架让html页面中用的是花括号来表示变量的,但是,这个也可以在tp5中进行修改,让其他的符号或者其他的值来代替花括号的作用。
![](http://upload-images.jianshu.io/upload_images/5273711-f927972a0173dbaf.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000)
![](http://upload-images.jianshu.io/upload_images/5273711-98ee96145629cfe0.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000)
在配置文件中,可以设置下面这个参数的值,来全局替换某个关键词为某个值
![](http://upload-images.jianshu.io/upload_images/5273711-de530bc113061e48.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000)
。
。