Maison  >  Article  >  développement back-end  >  Explication détaillée de la différence entre les versions ThinkPHP5.0 et ThinkPHP3.2

Explication détaillée de la différence entre les versions ThinkPHP5.0 et ThinkPHP3.2

小云云
小云云original
2018-02-12 14:25:421777parcourir

La version 5.0 est assez différente des versions précédentes. Cet article donne quelques-unes des principales différences de la version 5.0 pour les utilisateurs familiers avec la version 3.2. Cet article partage principalement avec vous les différences entre la version ThinkPHP5.0 et la version ThinkPHP3.2. L'éditeur le trouve plutôt bon, je vais donc le partager avec vous maintenant et le donner comme référence pour tout le monde. Suivons l'éditeur et jetons un œil. J'espère que cela pourra aider tout le monde.

URL et routage

L'accès aux URL dans la version 5.0 ne prend plus en charge le mode URL ordinaire, et le routage ne prend pas en charge la définition d'itinéraire régulière. Au lieu de cela, tout est modifié en routage de règles avec des règles variables (définition régulière). ). :

Les principales améliorations sont les suivantes :

Ajouter des règles de variables de routage ;
Ajouter la prise en charge des variables de combinaison
Ajouter un regroupement de ressources ; 🎜> Ajout de la prise en charge de la définition de fermeture ;
Ajout de la définition de la route MISS ;
Prise en charge de l'anti-analyse des règles de routage des URL

Objet de requête et objet de réponse

5.0 ajoute l'objet de requête Demande et 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.

L'espace de noms de l'application est unifié en tant qu'application (définissable) au lieu du nom du module ;

Le nom de classe du contrôleur n'a pas le suffixe Controller par défaut. Vous pouvez configurer le paramètre use_controller_suffix pour activer la classe du contrôleur. suffixe;

Contrôle La méthode d'opération du contrôleur utilise la méthode de retour pour renvoyer des données au lieu d'une sortie directe ;
Supprimez les méthodes pré- et post-opération d'origine
Ajoutez l'attribut beforeActionList pour définir les pré-opérations ; 🎜> Prise en charge de la définition et de l'accès du contrôleur à n'importe quel niveau ;
L'accès URL prend en charge le contrôleur de positionnement automatique

Base de données

La fonction de requête de base de données de 5.0 a été améliorée. à utiliser via le modèle peut être appelé directement via la classe Db. La fonction M d'origine Vous pouvez utiliser la fonction db à la place, par exemple :

version 3.2

M('User') ->where(['name'=>'thinkphp'])->find ();

Version 5.0

db('User')-> où('name','thinkphp')->find();

Les principales améliorations sont les suivantes :

Prise en charge des opérations de requête en chaîne

La requête de données prend en charge le renvoi d'objets, tableaux et objets PDOStatement ;

La requête d'ensemble de données prend en charge le retour des tableaux et des objets Collection ;

Ajoute un constructeur de requête, les modifications de la syntaxe de la requête ;
prend en charge la requête de fermeture ; 🎜> ajoute des événements d'écoute SQL ;

Modèle

Les modifications du modèle 5.0 sont essentiellement un concept entièrement orienté objet, y compris les modèles associés. ne porte plus Model, mais se distingue directement par l'espace de noms. L'appel de fonction D d'origine est remplacé par la fonction model et doit créer la classe de modèle correspondante, par exemple :

version 3.2

D. ("Utilisateur")->where(['name'=>'thinkphp'])->find( );

Version 5.0

model('Utilisateur ')->where('name','thinkphp')->find();


Les principales améliorations incluent :

Reconstruire le modèle d'association

Prise en charge du modèle d'agrégation ; ;

Abolir le modèle de vue (changer la méthode de requête de vue de la base de données) ;

Adopter le mécanisme Trait pour l'expansion du modèle ;

Ajouter des getters et des modificateurs ;

Ajouter l'écriture automatique des horodatages ; > Ajouter la conversion de champ de type ;

Prise en charge de l'accès au tableau ;
Prise en charge de la sérialisation JSON

Vérification automatique des données et achèvement automatique de la version 5.0 ; adopte la définition du validateur et effectue une vérification unifiée via la classe 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 l'exception. La page a été repensée, affichant des informations détaillées sur les erreurs pour un débogage facile.

Débogage et journalisation

La page Trace dans 5.0 est améliorée et prend en charge la console du navigateur pour afficher les informations de trace.

Le pilote de journalisation de la version 5.0 ajoute le mode Socket et utilise SocketLog pour prendre en charge le débogage à distance.

Constantes

La version 5.0 a abandonné la plupart des définitions de constantes d'origine, ne conservant que les définitions de constantes de chemin du framework. Les constantes restantes peuvent être complétées à l'aide des attributs ou méthodes pertinents de la classe App ou de la requête. class , ou redéfinissez vous-même les constantes requises.

Les constantes obsolètes incluent :

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

Fonction

Le framework de base de version 5.0 ne dépend d'aucune fonction personnalisée, mais encapsule toujours certaines fonctions courantes dans des fonctions d'assistance, vous pouvez redéfinir ou ajouter des fonctions d'assistance à volonté.

Recommandations associées :

Implémentation ThinkPHP5.0 du partage d'exemples de plug-in de téléchargement d'images

10 articles recommandés sur le framework thinkPHP5.0

Exemple de code de la portée de configuration simple du framework thinkPHP5.0

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!

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