Différences : 1. 3.2 prend en charge les modèles d'URL ordinaires et les définitions de routage régulières, mais 5.0 ne les prend pas en charge ; 2. 5.0 ajoute un nouvel objet de requête Demande et objet de réponse Réponse ; 3. 5.0 a une tolérance zéro pour les erreurs, mais pas 3.2. ; 4. Version 5.0 La plupart des définitions de constantes d'origine sont abandonnées et seules les définitions de constantes de chemin du framework sont conservées.
L'environnement d'exploitation de ce tutoriel : système Windows 7, version thinkphp v5.0, ordinateur Dell G3.
La version 5.0
est assez différente de la version précédente. Cet article donne quelques informations pour les utilisateurs familiers avec 3.2 version Les principales différences de <code>5.0
. 5.0
版本和之前版本的差异较大,本篇对熟悉3.2
版本的用户给出了一些5.0
的主要区别。
URL和路由
5.0
的URL访问不再支持普通URL
模式,路由也不支持正则路由定义,而是全部改为规则路由配合变量规则(正则定义)的方式:
主要改进如下;
请求对象和响应对象
5.0
新增了请求对象Request
和响应对象Response
,Request
统一处理请求和获取请求信息,Response
对象负责输出客户端或者浏览器响应。
模块和控制器
控制器的命名空间有所调整,并且可以无需继承任何的控制器类。
app
(可定义)而不是模块名;Controller
后缀,可以配置开启use_controller_suffix
参数启用控制器类后缀;return
方式返回数据 而非直接输出;beforeActionList
属性定义前置操作;数据库
5.0的数据库查询功能增强,原先需要通过模型才能使用的链式查询可以直接通过Db
类调用,原来的M
函数调用可以改用db
函数,例如:
3.2版本
M('User')->where(['name'=>'thinkphp'])->find();
5.0版本
db('User')->where('name','thinkphp')->find();
主要改进如下:
PDOStatement
对象;Collection
对象;模型
5.0
的模型变化是最大的,基本上模型是完全面向对象的概念,包括关联模型,模型类的后缀不再带Model
,直接由命名空间区分,原来的D
函数调用改为model
函数,并且必须创建对应的模型类,例如:
3.2版本
D('User')->where(['name'=>'thinkphp'])->find();
5.0版本
model('User')->where('name','thinkphp')->find();
主要改进包括:
Trait
机制;自动验证和自动完成
5.0的数据自动验证和自动完成和3.2版本区别较大,5.0的数据验证采用验证器定义并且通过thinkValidate
类进行统一的验证。自动完成则通过在模型里面定义修改器来完成。
异常
5.0
对错误零容忍,默认情况下会对任何级别的错误抛出异常(但可以在应用公共文件中设置错误级别),并且重新设计了异常页面,展示了详尽的错误信息,便于调试。
调试和日志
5.0
的页面Trace
强化,支持浏览器控制台查看Trace信息。
5.0
的日志驱动增加Socket
方式,采用SocketLog
URL et routage
L'accès URL de5.0
ne prend plus en charge le mode URL
normal, et le routage ne prend pas en charge les définitions d'itinéraire classiques, mais tous le sont changé en règles. La façon dont le routage coopère avec les règles variables (définition régulière) : 🎜🎜Les principales améliorations sont les suivantes : 🎜5.0
Ajout d'un objet de requête Demande
et d'une réponse l'objet Response
, Request
traite uniformément les demandes et obtient les informations sur la demande, et l'objet Response
est responsable de la sortie de la réponse du client ou du navigateur. 🎜🎜🎜🎜Modules et contrôleurs🎜🎜🎜🎜L'espace de noms du contrôleur a été ajusté et il n'est pas nécessaire d'hériter d'une classe de contrôleur. 🎜app
(définissable) au lieu du nom du module Controller ; par défaut code> suffixe, vous pouvez configurer et activer le paramètre <code>use_controller_suffix
pour activer le suffixe de classe du contrôleur ;
return
méthode pour renvoyer des données au lieu d'une sortie directe ; beforeActionList
pour définir les pré-opérations ; ; Db
. L'appel de fonction M
d'origine peut être. modifié pour utiliser la fonction db
, par exemple : 🎜🎜🎜Version 3.2🎜🎜 REQUEST_METHOD IS_GET IS_POST IS_PUT IS_DELETE IS_AJAX __EXT__ COMMON_MODULE MODULE_NAME CONTROLLER_NAME ACTION_NAME APP_NAMESPACE APP_DEBUG MODULE_PATH
PDOStatement
;Collection
; 5.0
a le plus grand changement de modèle. Fondamentalement, le modèle est complètement un objet. -concept orienté, y compris les modèles associés. Le suffixe de la classe model ne porte plus Model
, mais directement Distingué par l'espace de noms, l'appel de fonction D
d'origine est remplacé par le model
, et la classe de modèle correspondante doit être créée, par exemple : 🎜🎜🎜version 3.2 🎜🎜rrreee🎜🎜5.0 Les principales améliorations de la version 🎜🎜rrreee🎜 incluent : 🎜Trait
; thinkValidate
. La complétion automatique est réalisée en définissant des modificateurs dans le modèle. 🎜🎜🎜🎜Exceptions🎜🎜🎜🎜5.0
a une tolérance zéro pour les erreurs. Par défaut, des exceptions seront levées pour n'importe quel niveau d'erreur (mais le niveau d'erreur peut être défini dans le fichier public de l'application). et repensé La page d'exception affiche des informations détaillées sur les erreurs pour un débogage facile. 🎜🎜🎜🎜Débogage et journalisation🎜🎜🎜🎜La page Trace
de 5.0
a été améliorée pour prendre en charge l'affichage des informations de trace dans la console du navigateur. 🎜🎜Le pilote de journal de 5.0
ajoute la méthode Socket
et utilise SocketLog
pour prendre en charge le débogage à distance. 🎜🎜🎜🎜Constante🎜🎜🎜5.0
版本废弃了原来的大部分常量定义,仅仅保留了框架的路径常量定义,其余的常量可以使用App
类或者Request
类的相关属性或者方法来完成,或者自己重新定义需要的常量。
废除的常量包括:
REQUEST_METHOD IS_GET IS_POST IS_PUT IS_DELETE IS_AJAX __EXT__ COMMON_MODULE MODULE_NAME CONTROLLER_NAME ACTION_NAME APP_NAMESPACE APP_DEBUG MODULE_PATH
函数
5.0
版本核心框架不依赖任何自定义函数,但仍然封装了一些常用功能到助手函数,你可以随意重新定义或者增加助手函数。
【相关教程推荐:thinkphp框架】
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!