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