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)
{$info.status ? $info.msg : $info.error}还支持这种写法:{$varname.aa ?? 'xxx'}或{$varname.aa ?: 'xxx'}
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()); }
$list = model('User')->where('status',1)->paginate(10); $page = $this->render(); $this->assign('_list',$list); $this->assign('_page',$page); return $this->fetch();
<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('User'); $data['name'] = 'ThinkPHP'; $data['email'] = 'ThinkPHP@gmail.com'; $User->create($data); $User->add($data);//添加多条数据$dataList[] = array('name'=>'thinkphp','email'=>'thinkphp@gamil.com'); $dataList[] = array('name'=>'onethink','email'=>'onethink@gamil.com') $User->addAll($dataList);
//添加单条数据$data = ['foo' => 'bar', 'bar' => 'foo']; Db::table('think_user')->insert($data);//添加多条数据$data = [ ['foo' => 'bar', 'bar' => 'foo'], ['foo' => 'bar1', 'bar' => 'foo1'], ['foo' => 'bar2', 'bar' => 'foo2'] ]; Db::name('user')->insertAll($data);
Modifier les donnéesthinkhp3.2
$User = M("User"); // 实例化User对象// 要修改的数据对象属性赋值 $data['name'] = 'ThinkPHP';$data['email'] = 'ThinkPHP@gmail.com'; $User->where('id=5')->save($data); // 根据条件更新记录 where('id=5')->setField('name','ThinkPHP'); $data = array('name'=>'ThinkPHP','email'=>'ThinkPHP@gmail.com');// 更改用户的name值 $User-> where('id=5')->setField($data);更改用户的name和email的值 $User->where('id=5')->setDec('score',5); // 用户的积分减5 $User->where('id=5')->setInc('score',3); // 用户的积分加3
Db::table('think_user')->update(['name' => 'thinkphp','id'=>1]);//更新数据表中的数据 Db::table('think_user') ->where('id',1) ->setField('name', 'thinkphp');//更新某个字段的值 Db::table('think_user')->where('id', 1)->setInc('score',5);// score 字段加 5 Db::table('think_user')->where('id', 1)->setDec('score', 5);// score 字段减 5 Db::table('think_user')->where('id', 1)->setInc('score', 1, 10);//支持延时更新
Supprimer les donnéesthinkhp3.2
$User->delete('1,2,5'); // 删除主键为1,2和5的用户数据 $User->where('status=0')->delete(); // 删除所有状态为0的用户数据
// 根据主键删除Db::table('think_user')->delete(1); Db::table('think_user')->delete([1,2,3]);// 条件删除 Db::table('think_user')->where('id',1)->delete(); Db::table('think_user')->where('id','<',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 'hello,thinkphp!'; } }
namespace app\index\controller; class Index { public function index() { return 'hello,thinkphp!'; } }
IndexController.class.php
Index.php
5.0在控制器中输出模板,使用方法如下:
如果你继承think\Controller的话,可以使用:
return $this->fetch('index/hello');
如果你的控制器没有继承 think\Controller的话,使用:
return view('index/hello');
模型
如果非要对比与旧版本的改进,模型被分为数据库、模型、验证器三部分,分别对应M方法、模型、自动验证,同时均有所加强,下面做简单介绍。
数据库
5.0的数据库查询功能增强,原先需要通过模型才能使用的链式查询可以直接通过Db类调用,原来的M函数调用可以改用db函数,例如:
3.2版本
M('User')->where(['name'=>'thinkphp'])->find();
5.0版本
db('User')->where('name','thinkphp')->find();
模型
新版的模型查询增加了静态方法,例如:
User::get(1); User::all(); User::where('id','>',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版本的单字母函数对比如下:
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!