Maison  >  Article  >  développement back-end  >  À propos de l'utilisation du widget dans ThinkPHP3.1

À propos de l'utilisation du widget dans ThinkPHP3.1

不言
不言original
2018-06-19 16:12:511662parcourir

Cet 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!

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