Maison  >  Article  >  cadre php  >  La différence entre thinkphp3 et thinkphp5

La différence entre thinkphp3 et thinkphp5

爱喝马黛茶的安东尼
爱喝马黛茶的安东尼original
2019-06-19 15:43:253921parcourir

La différence entre thinkphp3 et thinkphp5

Quelle est la différence entre thinkphp3 et thinkphp5 ? Laissez-moi vous présenter les différences entre les deux :

1 Les différences d'utilisation entre thinkphp3.2 et thinkphp5

1. . Les anciennes fonctions à lettre unique ont été complètement remplacées, comme suit :

S=>cache,C=>config,M/D=>model,U=>url,I=>input,E=>exception,L=>lang,A=>controller,R=>action

2. Rendu du modèle :

$this->display() => return view()/return $this->fetch();

3 Appel du propre modèle dans le modèle :

$this => Db::table($this->table)
4. Dénomination lors de la création de nouveaux contrôleurs et modèles :

① Supprimez le suffixe du contrôleur du contrôleur : UserController => User

② Supprimez le suffixe du modèle : UserModel => User

5. Accès URL :

Si le nom du contrôleur utilise une casse camel, vous devez lier chaque lettre avec un trait de soulignement avant d'y accéder.

par exemple : Le contrôleur s'appelle AddUser, et l'accès se fait à l'aide de add_user

6 Dans TP5, il prend en charge la configuration des paramètres secondaires (c'est-à-dire un tableau bidimensionnel dans le fichier de configuration). Lecture des paramètres de configuration secondaires :

①Config::get('user.type');

②config('user.type');

7 Le modèle prend en charge trois. Opérations des méta-opérateurs :

{$info.status ? $info.msg : $info.error}还支持这种写法:{$varname.aa ?? 'xxx'}或{$varname.aa ?: 'xxx'}

Recommandations associées : "

Tutoriel vidéo php"

Balises intégrées TP5 :

Dans les balises. intégré au système, volist, switch, if, elseif, else, foreach, compare (y compris toutes les balises de comparaison), (non) présent, (non) vide, (non) défini, etc.

9. Vérification des données TP5 :

$validate = new Validate(['name' => 'require|max:25','email' => 'email']);
$data = ['name' => 'thinkphp','email' => 'thinkphp@qq.com'];
if(!validate->check($data)){
debug::dump($validate->getError());
}

Remarque : utilisez la fonction d'assistance pour instancier le validateur - $validate = validate('User');

10. TP5 implémente la pagination intégrée, utilisez comme suit. :

Interrogez les données utilisateur avec le statut 1 et affichez 10 éléments de données par page

$list = model('User')->where('status',1)->paginate(10);
$page = $this->render();
$this->assign('_list',$list);
$this->assign('_page',$page);
return $this->fetch();

Le code de sortie de pagination dans le fichier modèle est le suivant :

<div>{$_page}</div>

Deuxièmement, thinkphp3.2 et comparer les opérations de base de données thinkphp5

Ajouter des donnéesthinkhp3.2

//添加单条数据$User = M(&#39;User&#39;);
$data[&#39;name&#39;] = &#39;ThinkPHP&#39;;
$data[&#39;email&#39;] = &#39;ThinkPHP@gmail.com&#39;;
$User->create($data);
$User->add($data);//添加多条数据$dataList[] = array(&#39;name&#39;=>&#39;thinkphp&#39;,&#39;email&#39;=>&#39;thinkphp@gamil.com&#39;);
$dataList[] = array(&#39;name&#39;=>&#39;onethink&#39;,&#39;email&#39;=>&#39;onethink@gamil.com&#39;)
$User->addAll($dataList);

thinkphp5

//添加单条数据$data = [&#39;foo&#39; => &#39;bar&#39;, &#39;bar&#39; => &#39;foo&#39;];
Db::table(&#39;think_user&#39;)->insert($data);//添加多条数据$data = [
    [&#39;foo&#39; => &#39;bar&#39;, &#39;bar&#39; => &#39;foo&#39;],
    [&#39;foo&#39; => &#39;bar1&#39;, &#39;bar&#39; => &#39;foo1&#39;],
    [&#39;foo&#39; => &#39;bar2&#39;, &#39;bar&#39; => &#39;foo2&#39;]
];
Db::name(&#39;user&#39;)->insertAll($data);

Modifier les donnéesthinkhp3.2

$User = M("User"); // 实例化User对象// 要修改的数据对象属性赋值
$data[&#39;name&#39;] = &#39;ThinkPHP&#39;;$data[&#39;email&#39;] = &#39;ThinkPHP@gmail.com&#39;;
$User->where(&#39;id=5&#39;)->save($data); // 根据条件更新记录
where(&#39;id=5&#39;)->setField(&#39;name&#39;,&#39;ThinkPHP&#39;);
$data = array(&#39;name&#39;=>&#39;ThinkPHP&#39;,&#39;email&#39;=>&#39;ThinkPHP@gmail.com&#39;);// 更改用户的name值
$User-> where(&#39;id=5&#39;)->setField($data);更改用户的name和email的值
$User->where(&#39;id=5&#39;)->setDec(&#39;score&#39;,5); // 用户的积分减5
$User->where(&#39;id=5&#39;)->setInc(&#39;score&#39;,3); // 用户的积分加3

thinkhp5

Db::table(&#39;think_user&#39;)->update([&#39;name&#39; => &#39;thinkphp&#39;,&#39;id&#39;=>1]);//更新数据表中的数据
Db::table(&#39;think_user&#39;) ->where(&#39;id&#39;,1) ->setField(&#39;name&#39;, &#39;thinkphp&#39;);//更新某个字段的值
Db::table(&#39;think_user&#39;)->where(&#39;id&#39;, 1)->setInc(&#39;score&#39;,5);// score 字段加 5
Db::table(&#39;think_user&#39;)->where(&#39;id&#39;, 1)->setDec(&#39;score&#39;, 5);// score 字段减 5
Db::table(&#39;think_user&#39;)->where(&#39;id&#39;, 1)->setInc(&#39;score&#39;, 1, 10);//支持延时更新

Supprimer les donnéesthinkhp3.2

$User->delete(&#39;1,2,5&#39;); // 删除主键为1,2和5的用户数据
$User->where(&#39;status=0&#39;)->delete(); // 删除所有状态为0的用户数据

thinkphp5

// 根据主键删除Db::table(&#39;think_user&#39;)->delete(1);
Db::table(&#39;think_user&#39;)->delete([1,2,3]);// 条件删除    
Db::table(&#39;think_user&#39;)->where(&#39;id&#39;,1)->delete();
Db::table(&#39;think_user&#39;)->where(&#39;id&#39;,&#39;<&#39;,10)->delete();

Troisièmement, comparaison entre thinkphp5 et thinkphp3 Les développeurs de la version .X peuvent se familiariser et démarrer avec cette nouvelle version plus rapidement. Dans le même temps, il est également fortement recommandé aux développeurs d’abandonner leurs anciens schémas de pensée, car la 5.0 est une toute nouvelle version subversive et reconstruite. Anciennes idées de 3. Nous nous excusons pour les conseils incorrects. Dans la version 5.0, la méthode similaire à /id/1, qui peut obtenir 'id' via 'get', est officiellement abolie, à proprement parler. une URL n'appartient pas à $_GET. Elle peut désormais être obtenue via 'param' Get.

Modifications du modèle

La nouvelle version de la requête de modèle renvoie "l'objet" par défaut et le système ajoute la méthode "toArray" par défaut. " ou " select " " Essayez d'utiliser " toArray " pour convertir en tableau. J'espère que les développeurs pourront comprendre le concept " d'objet ", essayer d'utiliser " objet " pour utiliser des données ou utiliser la méthode " db " pour faire fonctionner le base de données, et vous rappelle également cette partie. Pour les développeurs qui abusent de « toArray », le résultat de « all » ou « select » est une collection de tableaux d'objets, qui ne peuvent pas être convertis à l'aide de « toArray ».

Nouvelles modifications de version

Convention de dénomination

Les noms de répertoires et de fichiers utilisent « minuscule + trait de soulignement ' , et commence par une lettre minuscule ; la bibliothèque de classes et les fichiers de fonctions sont uniformément suffixés par .php ; les noms de fichiers des classes sont définis dans les espaces de noms et le chemin de l'espace de noms est cohérent avec le chemin du fichier de bibliothèque de classes (y compris les majuscules). et minuscules); le nom de la classe et la classe. Les noms de fichiers doivent être cohérents et utiliser une dénomination en casse chameau (la première lettre est en majuscule)

Fonction

Le système ne repose plus sur aucune fonction, mais fournit uniquement l'encapsulation des opérations couramment utilisées. Fonction d'assistance ; les fonctions à une seule lettre sont obsolètes et le système charge la fonction d'assistance par défaut.

Routage

L'accès URL 5.0 ne prend plus en charge le mode URL ordinaire et le routage ne prend pas en charge les définitions d'itinéraire régulières. Au lieu de cela, tous sont modifiés en routage de règles avec des règles variables (. définition régulière), les détails spécifiques ne seront pas répétés ici.

Contrôleur

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 la bibliothèque de classes d'application est unifié en tant qu'application (modifiable) 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 controller_suffix pour activer le contrôleur. suffixe de classe ; méthode de fonctionnement du contrôleur Utilisez la méthode de retour pour renvoyer des données au lieu de la sortie directe ; abolissez les méthodes de pré- et post-opération d'origine

Comparaison des versions

3.2. méthode d'écriture du contrôleur de version

<?php
namespace Home\Controller;
use Think\Controller;
class IndexController extends Controller 
{    public function hello()
    {        echo &#39;hello,thinkphp!&#39;;
    }
}

Méthode d'écriture du contrôleur de version 5.0

namespace app\index\controller;
class Index
{    public function index()
    {        return &#39;hello,thinkphp!&#39;;
    }
}

Nom du contrôleur de version 3.2

IndexController.class.php

Nom du contrôleur de version 5.0

Index.php
Modèle de sortie correct dans le contrôleur

5.0在控制器中输出模板,使用方法如下:

如果你继承think\Controller的话,可以使用:

return $this->fetch(&#39;index/hello&#39;);

如果你的控制器没有继承 think\Controller的话,使用:

return view(&#39;index/hello&#39;);

模型

如果非要对比与旧版本的改进,模型被分为数据库、模型、验证器三部分,分别对应M方法、模型、自动验证,同时均有所加强,下面做简单介绍。

数据库

5.0的数据库查询功能增强,原先需要通过模型才能使用的链式查询可以直接通过Db类调用,原来的M函数调用可以改用db函数,例如:
3.2版本

M(&#39;User&#39;)->where([&#39;name&#39;=>&#39;thinkphp&#39;])->find();

5.0版本

db(&#39;User&#39;)->where(&#39;name&#39;,&#39;thinkphp&#39;)->find();

模型

新版的模型查询增加了静态方法,例如:

User::get(1); 
User::all();
User::where(&#39;id&#39;,&#39;>&#39;,10)->find();

自动验证

对比旧的版本,可以理解为之前的自动验证且不同于之前的验证;
ThinkPHP5.0验证使用独立的\think\Validate类或者验证器进行验证,不仅适用于模型,在控制器也可直接调用。

配置文件

新版对配置很多的配置参数或者配置层次都和之前不同了,建议大家要么看看代码,要么仔细通读下官方的开发手册,不要因为配置的问题浪费自己一整天的时间。

异常

5.0对错误零容忍,默认情况下会对任何级别的错误抛出异常,并且重新设计了异常页面,展示了详尽的错误信息,便于调试。

系统常量的废弃

5.0版本相对于之前版本对系统变化进行了大量的废弃,用户如果有相关需求可以自行定义
下面是废除常量

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等

部分常量可以在Request里面进行获取

助手函数

5.0助手函数和3.2版本的单字母函数对比如下:

La différence entre thinkphp3 et thinkphp5

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