Plug-in basé sur la réflexion Architecture n'est pas réellement classé comme un modèle, car il ne s'agit pas réellement d'un modèle, mais d'une série de concepts qui sont combinés pour former l'architecture du programme.
La méthode plug-in de l'API de réflexion est basée sur la détermination de la fonction du programme au moment de l'exécution, c'est-à-dire qu'elle permet la création de méthodes d'interface facultatives et détecte cette partie de la méthode d'interface lorsqu'elle est utilisée pour le la première fois. Seulement Ces interfaces ne seront utilisées que si elles existent dans le plug-in
Supposons qu'il existe une telle interface
interface IPlugin{ function getMenuItems(); function getArticles(); function getSideBars(); } class Someplugin implelents IPlugin{ public function getMenuItems(){ //没有菜单项 return null; } public function getArticles(){ //没有任何文章 return null; } public function getSidBars(){ //有侧边 return array("sidbarItem'); } } [html] 这种情况并不太合理,因为满足了接口的要求,为大量方法添加了不会用到的函数体,如果在API中有数百个方法,这样是行不通的。 反射API提供了一种解决方法,使用get_ declare d_classes()函数取得当前加载的类,并检测哪个类实现了IPlugin"标记"的方法。 在这里写了一个使用反射查找插件的方法 [code] function findPlugins(){ $plugins=array(); foreach (get_declared_classes() as $class){ $reflectionsClass=new ReflectionClass($class); if($reflectionsClass->implementsInterface('IPlugin')){ $plugins[]=$reflectionsClass; } } return $plugins; }
Afin de déterminer si une classe implémente une seule méthode, vous pouvez utiliser la méthode hasMethod() de la classe REfectionClass.
Déterminez les membres de la classe utilisés pour le menu
function computerMenu(){ $menu=array(); foreach (findPlugins() as $plugin){ if($plugin->hasMethod('getMenuItems')){ $reflectionMethod=$plugin->getMethod('getMenuItems'); if($reflectionMethod->is Static ()){ $items=$reflectionMethod->invoke(null); }else{ $pluginInstance=$plugin->newInstance(); $items=$reflectionMethod->invoke($pluginInstance); } $menu= array_merge ($menu,$items); } } return $menu; }
Après avoir obtenu l'instance de la classe, vous devez vérifier si elle peut être statiqueDétecter les appels la méthode API, si la méthode est statique, il suffit d'appeler la fonction Invoke(),
comme suit public Mixed Invoke(stdclass object, Mixed args=null)
Par contre, si la méthode n'est pas statique, vous devez obtenir une instance du plug-in pour appeler cette méthode, vous devez obtenir une instance de la classe à partir de l'objet Refectionclass,
appeler sa méthode newInstance(), puis utiliser la méthode Invocation() pour renvoyer le exemple et transmettez-le.
Déterminez les membres de la classe utilisés pour les articles et les côtés
function computeArticles(){ $articles=array(); foreach (findPlugins() as $plugin){ if($plugin->hasMethod('getArticles')){ $reflectionMethod=$plugin->getMethod('getArticles'); if($reflectionMethod->isStatic()){ $items=$reflectionMethod->invoke(null); }else{ $pluginInstance=$plugin->newInstance(); $items=$reflectionMethod->invoke($pluginInstance); } $articles=array_merge($articles,$items); } } return $articles; } function computeSidebars(){ $sidebars=array(); foreach (findPlugins() as $plugin){ if($plugin->hasMethod('getSidebars')){ $reflectionMethod=$plugin->getMethod('getSidebars'); if($reflectionMethod->isStatic()){ $items=$reflectionMethod->invoke(null); }else{ $pluginInstance=$plugin->newInstance(); $items=$reflectionMethod->invoke($pluginInstance); } $sidebars=array_merge($sidebars,$items); } } return $sidebars; }
Créez un plug-in réfléchissant qui implémente des fonctionnalités facultatives
class MyCoolPlugin implements IPlugin{ public static function getName(){return 'MyCoolPlugin';} public static function getMenuItems(){ //菜单项的数字索引数组 return array(array('description'=>'MyCoolPlugin','link'=>'/MyCoolPlugin')); } public static function getArticles(){ //文章的数字索引数组 return array(array('path'=>'/MyCoolPlugin','title'=>'This is a really cool article', 'text'=>'This article is cool because...')); } public static function getSideBars(){ //文章的侧边栏索引数组 return array(array('sideBars'=>'/MyCoolPlugin')); } }
Enfin, faites ceci. peut utiliser ce plug-in :
$menu=computeArticles(); $sidebars=computeSidebars(); $articles=computeArticles(); print_r($menu); print_r($sidebars); print_r($articles);
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!