Heim >PHP-Framework >Denken Sie an PHP >Die thinkphp D-Methode gibt was zurück

Die thinkphp D-Methode gibt was zurück

青灯夜游
青灯夜游Original
2022-03-15 18:51:271723Durchsuche

In thinkphp kann die D-Methode das instanziierte Modellobjekt zurückgeben. Die D-Methode wird zum Instanziieren einer benutzerdefinierten Modellklasse verwendet. Sie ist eine Kapselung der Modellklasseninstanziierung durch das ThinkPHP-Framework. Die Syntax lautet „D('[Projekt://][Gruppe/]Modell','Modellebenenname ')", Der Rückgabewert ist das instanziierte Modellobjekt.

Die thinkphp D-Methode gibt was zurück

Die Betriebsumgebung dieses Tutorials: Windows 7-System, Thinkphp v5.1-Version, Dell G3-Computer.

D-Methode sollte die am häufigsten verwendete Methode sein, um benutzerdefinierte Modellklassen zu instanziieren. Sie ist eine Kapselung der Modellklasseninstanziierung durch das ThinkPHP-Framework und unterstützt projektübergreifende Aufrufe Das Aufrufformat lautet wie folgt:

D('[项目://][分组/]模型','模型层名称')

Der Rückgabewert der D-Methode ist das instanziierte Modellobjekt.

D-Methode kann die Modellklasse automatisch erkennen, die benutzerdefinierte Modellklasse wird instanziiert. Wenn sie nicht vorhanden ist, wird die Modellbasisklasse gleichzeitig instanziiert Wurde instanziiert, wird die Deinstantiierung nicht wiederholt. Die häufigste Verwendung der

D-Methode besteht darin, ein benutzerdefiniertes Modell des aktuellen Projekts zu instanziieren. Beispiel:

// 实例化User模型
$User = D('User');

importiert die Datei Lib/Model/UserModel.class.php unter dem aktuellen Projekt und instanziiert dann das UserModel Klasse, daher kann der eigentliche Code dem folgenden entsprechen:

import('@.Model.UserModel');
$User = new UserModel();

D-Methode kann die Instanziierung von Modellen über Gruppen und Projekte hinweg unterstützen, zum Beispiel:

//实例化Admin项目的User模型
D('Admin://User')
//实例化Admin分组的User模型
D('Admin/User')

Ab Version 3.1, aufgrund der zusätzlichen Unterstützung für hierarchische Modelle, D-Methode kann auch instanziiert werden. Transformieren Sie andere Modelle, zum Beispiel:

// 实例化UserService类
$User = D('User','Service');
// 实例化UserLogic类
$User = D('User','Logic');
D('User','Service');

importiert Lib/Service/UserService.class.php und instanziiert es.

Erweitertes Wissen: Der Hauptunterschied zwischen D und M besteht darin, dass

Die M-Methode keine Modellklassendatei erstellen muss und die M-Methode die Modellklasse nicht liest, sodass die automatische Überprüfung standardmäßig ungültig ist. Es kann jedoch dynamisch zugewiesen werden, um dies zu erreichen

und die D-Methode muss eine Modellklasse erstellen.

Wir können die folgenden zwei Methoden verwenden, um ein Zuordnungsobjekt einer Datentabelle zu erstellen

Die erste: $Test = D('Test')$Test = D(‘Test')

第二种:$Test = new Model(‘Test')

虽然这两种都可以对数据进行select,insert,delete,udpate操作,在

数据验证上有很大的不同,

用第一种方式实例一个模型就会有数据检查功能,如果 title 没有填写的话就会提示 “请输入标题” (这个是tp提供的一个自动验证功能,当然也需要在相应的model中定义好验证条件);

如果用第二种就没有了这个数据验证功能,需要手动验证。

总结如下:

  • D函数实例化的是你当前项目的Lib/Model下面的模块。

  • 如果该模块不存在的话,直接返回实例化Model的对象(意义就与M()函数相同)。

  • 而M只返回,实例化Model的对象。它的$name参数作为数据库的表名来处理对数据库的操作。

通俗点说:

  • D就是实例化一个基于Model文件的Model。

  • M则是通过直接实例化Model方法(ThinkPHP基类)来动态的实例化一个Model对象,即使这个对应的Model文件不存在。

再通俗一点说:

  • M实例化参数是数据库的表名。

  • D实例化的是你自己在Model文件夹下面建立的模型文件。

  • D就是在你没有定义模型的时候,系统自动帮你定义一个模型,这样你才进行简单的数据输入或者输出。

  • 每一个Action文件都应该对应Model文件的,如果你定义了Model的话,

如:$Form = D(“User”)就可以改成$Form = new  UserModel();

Die zweite: $ Test = neues Modell ('Test') <p><a href="//m.sbmmt.com/phpkj/thinkphp/" target="_blank">Obwohl beide Vorgänge zum Auswählen, Einfügen, Löschen und Aktualisieren von Daten ausführen können, gibt es einen großen Unterschied bei der </a></p>Datenüberprüfung 🎜🎜Verwenden Sie die erste Wenn Sie ein Modell instanziieren, verfügt es über eine Datenüberprüfungsfunktion. Wenn der Titel nicht ausgefüllt ist, wird die Meldung „Bitte geben Sie den Titel ein“ angezeigt (dies ist eine von TP bereitgestellte automatische Überprüfungsfunktion, und natürlich müssen die Überprüfungsbedingungen definiert werden im entsprechenden Modell); 🎜 🎜Wenn Sie die zweite Methode verwenden, steht Ihnen diese Datenüberprüfungsfunktion nicht zur Verfügung und Sie müssen sie manuell überprüfen. 🎜🎜Die Zusammenfassung lautet wie folgt: 🎜<ul style="list-style-type: disc;"> <li>🎜Die D-Funktion instanziiert das Modul unter der Bibliothek/dem Modell Ihres aktuellen Projekts. 🎜</li> <li>🎜Wenn das Modul nicht existiert, geben Sie direkt das Objekt des instanziierten Modells zurück (die Bedeutung ist dieselbe wie bei der M()-Funktion). 🎜</li> <li>🎜Und M gibt nur das Objekt zurück, das das Modell instanziiert. Sein Parameter $name wird als Tabellenname der Datenbank verwendet, um Vorgänge in der Datenbank abzuwickeln. 🎜</li> </ul>🎜Laienhaft ausgedrückt: 🎜<ul style="list-style-type: disc;"> <li>🎜D bedeutet, ein Modell basierend auf einer Modelldatei zu instanziieren. 🎜</li> <li>🎜M instanziiert ein Modellobjekt dynamisch, indem es die Modellmethode (ThinkPHP-Basisklasse) direkt instanziiert, auch wenn die entsprechende Modelldatei nicht vorhanden ist. 🎜</li> </ul>🎜Um es einfacher auszudrücken: 🎜<ul style="list-style-type: disc;"> <li>🎜M Instanziierungsparameter ist der Tabellenname der Datenbank. 🎜</li> <li>🎜D instanziiert die Modelldatei, die Sie im Modellordner erstellt haben. 🎜</li> <li>🎜D bedeutet, dass das System automatisch ein Modell für Sie definiert, wenn Sie kein Modell definieren, sodass Sie eine einfache Dateneingabe oder -ausgabe durchführen können. 🎜</li> <li>🎜Jede Aktionsdatei sollte einer Modelldatei entsprechen, 🎜</li> </ul>🎜Zum Beispiel: <code>$Form = D("User" ) kann in $Form = new UserModel(); geändert werden (Benutzer bezieht sich auf den Namen Ihrer Modelldatei). 🎜🎜【Empfehlung für entsprechende Tutorials: 🎜Thinkphp Framework🎜】🎜

Das obige ist der detaillierte Inhalt vonDie thinkphp D-Methode gibt was zurück. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn