Maison >php教程 >php手册 >ThinkPHP框架一,ThinkPHP框架

ThinkPHP框架一,ThinkPHP框架

WBOY
WBOYoriginal
2016-06-16 09:16:251479parcourir

ThinkPHP框架一,ThinkPHP框架

1.1 框架的概念

框架其实就是可重用代码的集合,框架的代码是框架架构的代码,不是业务逻辑代码,框架代码保护类.方法.函数等等,框架代码按照一定的规则组合起来就形成了框架。

1.2 不使用框架开发的时候遇到的问题

  1.代码编写没有统一的规范

  2.项目功能不能很好的拆分

  3.一个局部的微小改动可能会影响全局

  4.项目的升级比较麻烦

1.3 使用框架的好处

  1.有利于团队统一的代码风格

  2.将精力全部集中到业务逻辑上,无需关心底层框架

  3.快速.稳定高效的搭建程序

  4.节省大量代码

  5.后期维护升级很方便

1.5 相关的框架

  1. zendframwork: 有zend官方发布(zend 公司是维护升级PHP语言的公司),功能非常的强大,是一个重量级的框架

  2.Yii:由国人开发的重量级的框架,这个框架把代码的可重用性发挥到极致

  3.cakePHP:国外的框架,速度慢

  4.symfony:国外的框架

  5.CI:(code Igniter),轻量级框架,运行速度快

  6.ThinkPHP框架,免费的,开源的,快速,简单面向对象(里面的代码既有面向对象,也有面向过程),原名FCS,2007年元旦更名为ThinkPHP

1.6 ThinkPHP文件结构

  从http://www.thinkphp.cn/官方网站上下载TP框架,下载完成后进行解压,第一类目录里  的ThinkPHP即是我们框架的核心代码,类似于Framework文件夹

  Conf:配置文件夹,供建立在此TP框架的所有项目使用

  Library:类库

1.7.1 ThinkPHP下的Library文件夹

  Behavior:框架运行时侯辅助的类

  Think:ThinkPHP核心的代码

  Vendor:第三方的一些插件

1.7.2 ThinkPHPLibrary下的Think文件夹

  需要注意的几个文件:

  Controller.class.php:基础控制器

  Model.class.php:基础模型

  Think.class.php:每次请求都要执行带文件

  View.class.php:基础视图

1.8 搭建框架的结构

  在站点下新建一个index.php(入口文件),在index.php中输入:

  define('APP_PATH','./application/'); //定义项目文件夹,需要以/结尾

  require './ThinkPHP/ThinkPHP.php';   //包含ThinkPHP.php文件

注意:在TP框架中可以支持多个入口文件,(也就是说支持多个项目);

1.8.1 define('APP_PATH','./application/')

  定义项目文件夹,第一次执行该页面的时候,如果没有application文件夹,会自动创建application文件夹。当执行ThinkPHP.php文件时,第一次会自动搭建ThinkPHP框架结构。

1.9 创建控制器

  控制器是一个类文件,规范如下:

  1.存放在模块(平台)文件夹下的Controller文件夹

  2.类名:控制器+Controller,用帕斯卡命名法

  3.类名和文件名同名

  4.文件名以 .class.php结尾

  5.ThinkPHP默认使用UTF-8编码

  6.尽量区分大小写,Windows中没有问题的,但是Linux中会区分大小写

注意创建控制器的时候命名空间和引入基础控制器。

1.10 ThinkPHP的4中路由

    要精确到定位到方法上,需要3个参数:平台.控制器.方法,这三个参数。

a)普通模式:

  语法:http://网址/index.php/m=模块&c=控制器&a=方法

b)pathinofo()模式:

语法:http://网址/index.php/模块/控制器/方法

c) 兼容模式:

  语法:http://网址/index.php?s=/模块/控制器/方法

d) rewrite 重写模式:

  URL自定义功能通过重写路由可以使得URL便简介还可以隐藏真实的路径。

  伪静态技术就是重写模式。

需要用到的配置项:

  'URL_ROUTER_ON' => true, //开启路由

  'URL_ROUTE_RULES' => array(

  'test' => 'home/Goods/test',

), //路由规则

重定向传递参数

1.11 定义.调用模板

1.11.1 规则

  TP框架调用模板非常简单,功能也很强大。它有自身的一些规则

  1.模板都放在view目录中

  2.一个控制器对应一个文件夹,一个方法对应一个页面

1.11.2 调用模板

  $this->display();

1.11.3 在控制器中给变量赋值

  $this->assign('name','tom') //第一种方法

  $this->sex='男'; //第二种方法

1.11.4 在模板中取值

  {$name}

1.12 项目分组

  一个项目至少分成两组,一个前台,一个后台,每组都有自己的MVC。当TP框架自动生成项  目架构的时候会自动生成一个前台的分组。

  在和Home同级的目录中新建Admin文件夹(后台文件夹),在文件夹中新建自己的MVC

1.13 系统常量

  __SELF__ : 当前请求的地址

  __MODEL__ :当前模块

  __CONTROLLER__ :当前控制器

  __ACTION__ : 当前方法

get_defined_constants(true)显示所有的常量,true表示分组显示。

问题:__CONTROLLER__常量是PHP的常量,我们发现直接将此常量写在模板中一样可以解析,请问为什么PHP常量可以在HTML模板中输出?在PHP定义一个常量NAME,如何在模板中输出NAME的值?

在ContentReplaceBehavior.class.php 文件templateContentReplace()方法中添加一个字符串替换

1.14 在页面的底部显示日志信息

'SHOW_PAGE_TRACE'   =>  true    //在页面的底部显示日志信息

配置后会在页面右下角出现一个绿色的小图标

1.15  TP生产和开发模式

define('APP_DEBUG', TRUE);      //开发模式

define('APP_DEBUG', false);      //生产模式

1.15.1 开发模式

  1.错误提示比较友好

  2.代码的修改会立即显示效果

  3.执行效率低

1.16.2 生成模式

  1.错误提示比较模糊

  2.会把很多核心代码文件制作成一个缓存文件(common~runtime.php),这样原来需要加载很多文件的请求现在只要加载一个文件即可。节省了很多打开、关闭的开销。

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn