À propos de l'utilisation du widget dans ThinkPHP3.1
Jun 19, 2018 pm 04:12 PMCet article présente principalement la nouvelle utilisation de Widget dans ThinkPHP3.1. Les amis qui en ont besoin peuvent s'y référer
La version ThinkPHP3.0 de la prise en charge de Widget pour Action et View est relativement insuffisante et ne peut être implémentée que. Sortie de rendu de modèle de base. La fonction MVC multicouche apportée par la sortie de la version 3.1 a apporté de nouvelles idées sur la façon dont nous implémentons les widgets. Voyons comment l'implémenter.
Depuis que ThinkPHP 3.1 ajoute la prise en charge du MVC multicouche, la version 3.1 peut prendre en charge les fonctions de contrôleur multicouche, nous pouvons donc ajouter une autre couche à la couche contrôleur : la couche Widget.
Tout d'abord, créez un répertoire Widget sous le répertoire Lib du projet, et créez une classe TestWidget (Lib/Widget/TestWidget.class.php) comme suit :
class TestWidget extends Action{ public function hello($name=''){ echo ("hello,".$name."!"); } }
On voit que la différence entre TestWidget et avant est qu'il n'hérite pas de la classe Widget, mais hérite directement de la classe Action. Cela signifie que les méthodes Action peuvent être directement appelées dans TestWidget, y compris le rendu. de modèles de sortie.
Une fois la définition terminée, comment appelle-t-on ce Widget ? L’utilisation de la méthode W ne fonctionnera certainement pas. Cette fois, la méthode R est nécessaire. La fonction de la méthode
R est d'appeler le fonctionnement du module à distance, mais la version 3.1 lui a donné un nouveau rôle et peut prendre en charge l'appel des méthodes de fonctionnement de toutes les couches du contrôleur. Par conséquent, nous pouvons appeler le Widget dans le modèle comme. ceci :
{:R('Test/hello',array('ThinkPHP'),'Widget')}
peut être affiché dans une certaine zone de la page :
hello,ThinkPHP!
Étant donné que les autres couches de contrôleur, à l'exception du contrôleur Action, ne sont pas accessibles directement via l'URL, cette méthode Widget ne peut être appelée qu'en interne via la méthode R.
Vous pouvez appeler Model dans la classe TestWidget pour générer d'autres données. Si vous avez besoin de restituer votre propre modèle, vous pouvez simplement appeler directement la méthode d'affichage.
class TestWidget extends Action{ public function hello($name=''){ $this->assign('name',$name); $this->display('Test:hello'); } }
Nous créons un fichier modèle hello (Tpl/Test/hello.html) sous le répertoire Tpl/Test/ du projet et ajoutons la sortie :
Hello,{$name}!
Si vous souhaitez mettre le fichier modèle dans le répertoire courant comme le Widget précédent, vous pouvez utiliser :
class TestWidget extends Action{ public function hello($name=''){ $this->assign('name',$name); $this->display(dirname(__FILE__).'/Test/hello.html'); } }
À ce stade, vous pouvez placer le fichier modèle hello que vous venez de définir dans le répertoire Widget/Test/.
Ce qui précède représente l'intégralité du contenu de cet article. J'espère qu'il sera utile à l'étude de chacun. Pour plus de contenu connexe, veuillez faire attention au site Web PHP chinois !
Recommandations associées :
Méthode d'exportation vers Excel ou CSV basée sur php
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!

Article chaud

Outils chauds Tags

Article chaud

Tags d'article chaud

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

11 meilleurs scripts de raccourcissement d'URL PHP (gratuit et premium)

Travailler avec les données de session Flash dans Laravel

Misque de réponse HTTP simplifié dans les tests Laravel

Construisez une application React avec un Laravel Back End: Partie 2, React

Curl dans PHP: Comment utiliser l'extension PHP Curl dans les API REST

12 meilleurs scripts de chat PHP sur Codecanyon
