thinkphp ist der MVC-Modus. ThinkPHP basiert auf dem MVC-Modell und unterstützt mehrschichtiges (Multi-Layer) Design. Es handelt sich um ein Open-Source-Leichtbau-PHP-Framework, das entwickelt wurde, um die Anwendungsentwicklung auf Unternehmensebene und die agile WEB-Anwendungsentwicklung zu vereinfachen.
Die Betriebsumgebung dieses Tutorials: Windows 7-System, Thinkphp v5.1-Version, Dell G3-Computer.
ThinkPHP basiert auf dem MVC-Modell und unterstützt mehrschichtiges Design.
ThinkPHP ist ein schnelles, kompatibles und einfaches, leichtes PHP-Entwicklungsframework. Es wurde Anfang 2006 geboren. Es wurde am Neujahrstag 2007 offiziell in ThinkPHP umbenannt. Es wurde in Übereinstimmung mit Apache2 veröffentlicht Die Open-Source-Vereinbarung wurde aus der Struts-Struktur übernommen und verbessert und perfektioniert, während sie gleichzeitig auf viele hervorragende ausländische Frameworks und Muster zurückgreift, eine objektorientierte Entwicklungsstruktur und ein MVC-Muster verwendet und Struts-Ideen und TagLib (Tag-Bibliothek), RoRs ORM, integriert Zuordnung und ActiveRecord-Muster.
M (Modell) – Modellklasse
Modell
Die grundlegende Modellklasse in ThinkPHP ist die ThinkModel-Klasse, die grundlegende CURD-, ActiveRecord-Modus-, kohärente Operationen und statistische Abfragen sowie einige erweiterte Funktionen vervollständigt gekapselt in weitere Modellerweiterungen.
Hinweis: Das Design der Basismodellklasse ist sehr flexibel. Sie können sogar ORM- und CURD-Operationen für verwandte Datentabellen durchführen, ohne dass eine Modelldefinition erforderlich ist definiert.
Modelldefinition
Die Modellklasse muss nicht definiert werden. Sie muss nur definiert werden, wenn unabhängige Geschäftslogik oder Attribute vorhanden sind.
Modellklassen müssen normalerweise die ThinkModel-Klasse oder ihre Unterklassen erben. Das Folgende ist die Definition einer HomeModelUserModel-Klasse:
namespace Home\Model; use Think\Model; class UserModel extends Model{ }
Die Rolle der Modellklasse besteht in den meisten Fällen darin, die Datenbank zu betreiben wird gemäß den Spezifikationen des Systems benannt. In den meisten Fällen kann es automatisch der Datentabelle entsprechen.
Modellname | Konvention entsprechend der Datentabelle (vorausgesetzt, die Präfixdefinition der Datentabelle lautet „think_“) |
---|---|
UserModel | think_user |
UserTypeModel | think_user _Typ |
V(view)– 视图层
模板定义
每个模块的模块文件是独立的,为了对模块文件更加有效的管理,ThinkPHP对模块文件进行目录划分,默认的模板文件定义规则是:
视图目录/[模块主题/]'控制器名/操作名/操作名+模板后缀
默认的视图目录是模块的View目录(模块可以有多个视图文件目录),框架的默认视图文件后缀是.html
。
在每个模块主题下面,是以模块下面的控制器名为目录,然后是每个控制器的具体操作模板文件,如:
User控制器的add操作 对应的模块文件就应该是: ./Application/Home/View/User/add.html
如果默认视图层不是View,设置如: 'DEFAULT_V_LAYER'=>'Template',//设置默认的视图层名称
,对应的模板文件就变成了:./Application/Home/Template/User/add.html
。
模板文件的默认后缀是.html
,可以通过TMPL_TEMPLATE_SUFFIX来配置。 'TMPL_TEMPLATE_SUFFIX'=>'.tpl'
定义后,User控制器的add操作 对应的模板文件就变成是:./Application/Home/View/User/add.tpl
模板主题
模板主题可以对相同的控制器输出进行不同的布局和样式调整
一个模块需要支持多套模板文件的话,就可以使用模板主题功能。默认情况下,没有开启模板主题功能,如果需要开启,设置DEFAULT_THEME参数即可:
// 设置默认的模板主题 <br> 'DEFAULT_THEME'=>'default' <br>
采用模板主题后,需要在视图目录下面创建对应的主题目录,和不启用模板主题的情况相比,模板文件只是多了一层目录:
View/User/add.html //没有启用模板主题之前 View/default/User/add.html //启用模板主题之后
在视图渲染输出之前,我们可以通过动态设置来改变需要使用的模板主题。
//在控制器中动态改变模板主题 $this->theme('blue')->display('add');
模板赋值
如果要在模板中输出变量,必须在控制器中把变量传递给模板,通过assign方法对模板变量赋值
$this->assign('name',$value);//下面的写法是等效的 $this->name=$value;
assign方法必须在display
和show方法
之前调用,并且系统只会输出设定的变量,其他变量不会输出(系统变量例外)。
系统变量可以通过特殊的标签输出,无需赋值模板变量
赋值后,就可以在模板文件中输出变量,如果使用的是内置模板的话,就可以这样输出:{$name}
输出多个模板变量,可以使用下面的方式:
$array['name'] = 'thinkphp'; $array['email'] = 'fdsf@123.com'; $array['phone'] = '123456789'; $this->assign($array);
模板渲染
模板定义后就可以渲染模板输出,系统也支持直接渲染内容输出,模板赋值必须在模板渲染之前操作。
渲染模板
渲染模板输出最常用的是使用display方法,调用格式: display('[模板文件]'[,'字符编码'][,'输出类型'])
模板文件的写法支持下面几种:
用法 | 描述 |
---|---|
不带任何参数 | 自动定位当前操作的模板文件 |
[模块@][控制器:][操作] | 常用写法,支持跨模块 模板主题可以和theme方法配合 |
完整的模板文件名 | 直接使用完整的模板文件名(包括模板后缀) |
eg.
//不带任何参数 自动定位当前操作的模板文件 $this->display();
通常默认的视图目录是View
如果没有按照模板定义的规则来定义模板文件(或者需要调用其他控制器下面的某个模板),使用:
//表示调用当前控制器下面的edit模块 $this->display('edit'); //表示调用Member控制器下面的read模块 $this->display('Member:read');
如果我们使用了模板主题功能,那么也可以支持主题调用,使用:
\\表示调用blue主题下面的User控制器的edit模块 $this->theme('blue')->display('User:edit');
获取模板地址
T函数用于生成模板文件名,用法: T([资源://][模块@][主题/][控制器/]操作,[视图分层])
T函数的返回值为一个完整的模板文件名,可以直接用于display和fetch方法进行渲染输出。
eg.
T('Public/menu'); //返回 当前模块/View/Public/menu.html T('blue/Public/menu'); //返回 当前模块/View/blue/Public/menu.html T('Public/menu','Tpl'); //返回 当前模块/Tpl/Public/menu.html T('Admin@Public/menu'); //返回 Admin/View/Public/menu.html
在display方法中直接使用T函数
//使用T函数输出模板 $this->display(T('Admin@Public/menu'));
T函数可以输出不同的视图分层模块。
获取内容
如果需要获取渲染模板的输出内容而不是直接输出,可以使用fetch方法。
eg. $content = $this->fetch('Member:edit');
使用fetch方法获取渲染内容后,可以进行过滤和替换等操作。
渲染内容
如果没有定义任何模板文件,或者把模板内容存储到数据库的话,就需要使用show方法来渲染输出。
show方法调用格式:
show(‘渲染内容’[,’字符编码’][,’输出类型’])
eg.$this->show($content);
【相关教程推荐:thinkphp框架】
Das obige ist der detaillierte Inhalt vonWas ist der Thinkphp-Modus?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

thinkphp是国产框架。ThinkPHP是一个快速、兼容而且简单的轻量级国产PHP开发框架,是为了简化企业级应用开发和敏捷WEB应用开发而诞生的。ThinkPHP从诞生以来一直秉承简洁实用的设计原则,在保持出色的性能和至简的代码的同时,也注重易用性。

本篇文章给大家带来了关于thinkphp的相关知识,其中主要介绍了关于使用think-queue来实现普通队列和延迟队列的相关内容,think-queue是thinkphp官方提供的一个消息队列服务,下面一起来看一下,希望对大家有帮助。

thinkphp基于的mvc分别是指:1、m是model的缩写,表示模型,用于数据处理;2、v是view的缩写,表示视图,由View类和模板文件组成;3、c是controller的缩写,表示控制器,用于逻辑处理。mvc设计模式是一种编程思想,是一种将应用程序的逻辑层和表现层进行分离的方法。

本篇文章给大家带来了关于thinkphp的相关知识,其中主要介绍了使用jwt认证的问题,下面一起来看一下,希望对大家有帮助。

thinkphp扩展有:1、think-migration,是一种数据库迁移工具;2、think-orm,是一种ORM类库扩展;3、think-oracle,是一种Oracle驱动扩展;4、think-mongo,一种MongoDb扩展;5、think-soar,一种SQL语句优化扩展;6、porter,一种数据库管理工具;7、tp-jwt-auth,一个jwt身份验证扩展包。

本篇文章给大家带来了关于ThinkPHP的相关知识,其中主要整理了使用think-queue实现redis消息队列的相关问题,下面一起来看一下,希望对大家有帮助。

thinkphp查询库是否存在的方法:1、打开相应的tp文件;2、通过“ $isTable=db()->query('SHOW TABLES LIKE '."'".$data['table_name']."'");if($isTable){...}else{...}”方式验证表是否存在即可。

thinkphp设置伪静态去除目录的方法:1、在httpd.conf配置文件中加载mod_rewrite.so模块;2、将httpd.conf中Allowoverride None的None改为All;3、修改对应的项目配置文件;4、在项目的根目录下面建立一个.htaccess文件即可。


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

MantisBT
Mantis ist ein einfach zu implementierendes webbasiertes Tool zur Fehlerverfolgung, das die Fehlerverfolgung von Produkten unterstützen soll. Es erfordert PHP, MySQL und einen Webserver. Schauen Sie sich unsere Demo- und Hosting-Services an.

SecLists
SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

PHPStorm Mac-Version
Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool

Dreamweaver CS6
Visuelle Webentwicklungstools

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung