Heim  >  Artikel  >  php教程  >  ThinkPHP框架一,ThinkPHP框架

ThinkPHP框架一,ThinkPHP框架

WBOY
WBOYOriginal
2016-06-16 09:16:251416Durchsuche

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),这样原来需要加载很多文件的请求现在只要加载一个文件即可。节省了很多打开、关闭的开销。

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn