Новости Joomla

Как триггерить события для плагинов на манер Joomla 5+?В Joomla 6 должны удалить метод...

Как триггерить события для плагинов на манер Joomla 5+?В Joomla 6 должны удалить метод...

👩‍💻 Как триггерить события для плагинов на манер Joomla 5+?В Joomla 6 должны удалить метод triggerEvent(), с помощью которого раньше вызывались события для плагинов. Теперь чтобы в своём коде вызвать событие для плагина и получить от него результаты нужно:- создать объект класса события- передать в него параметры

use Joomla\CMS\Event\AbstractEvent;use Joomla\CMS\Factory;use Joomla\CMS\Plugin\PluginHelper;// Грузим плагины нужных группPluginHelper::importPlugin('system');// Создаём объект события$event = AbstractEvent::create('onAfterInitUniverse', [    'subject' => $this,    'data'    => $data, // какие-то данные    'article' => $article, // ещё материал вдовесок    'product' => $product, // и товаров подвезли]);// Триггерим событиеFactory::getApplication()->getDispatcher()->dispatch(    $event->getName(), // Тут можно строку передать 'onAfterInitUniverse'    $event);// Получаем результаты// В случае с AbstractEvent это может быть не 'result',// а что-то ещё - куда сами отдадите данные.// 2-й аргумент - значение по умолчанию, // если не получены результаты$results = $event->getArgument('result', []);
Плюсы такого подхода - вам не нужно запоминать порядок аргументов и проверять их наличие. Если вы написали свой класс события, то в плагине можно получать аргументы с помощью методов $event->getArticle(), $event->getData(), $event->getProduct() и подобными - реализуете сами под свои нужды. Если такой класс события написали, то создаёте экземпляр своего класса события и укажите его явно в аргументе eventClass
use Joomla\Component\MyComponent\Administrator\Event\MyCoolEvent;$event = MyCoolEvent::create('onAfterInitUniverse', [    'subject'    => $this,    'eventClass' => MyCoolEvent::class, // ваш класс события    'data'       => $data, // какие-то данные    'article'    => $article, // ещё материал вдовесок    'product'    => $product, // и товаров подвезли]);
Ожидаемо, что класс вашего события будет расширять AbsractEvent или другие классы событий Joomla.🙁 Есть неприятный нюанс - нельзя просто так вызывать событие и ничего не передать в аргументы. Аргумент subject обязательный. Но если вы всё-таки не хотите туда ничего передавать - передайте туда пустой stdClass или объект Joomla\registry\Registry.
@joomlafeed#joomla #php #webdev

0 Пользователей и 1 Гость просматривают эту тему.
  • 4 Ответов
  • 1624 Просмотров
*

dvtimofei

  • Захожу иногда
  • 111
  • 4 / 1
Запрос к БД
« : 16.10.2008, 17:08:20 »
Добрый вечер, у меня при добавлени пункта меню в главное меню, добовляеться один запрос к БД, это нормально? А  если пунктов будет 100 то будет и 100 запросов ?
*

Lord Glue

  • Захожу иногда
  • 95
  • 66 / 0
  • добрый пандо
Re: Запрос к БД
« Ответ #1 : 16.10.2008, 18:12:15 »
нет... будет 1 запрос, а его результат - 100 пунктов
*

dvtimofei

  • Захожу иногда
  • 111
  • 4 / 1
Re: Запрос к БД
« Ответ #2 : 16.10.2008, 18:55:55 »
Тогда я немного не понимаю,
я запускаю реим откладки.
Смотрю допусттим у меня 22 запроса к бд, и 2 ссылки на разный материал в Главонм меню,
Когда я добавляю еше одну ссылку, в откладке сановиться 23 запроса и так далее
*

Helios

  • Захожу иногда
  • 421
  • 31 / 1
  • Аэтошозадеталь?
Re: Запрос к БД
« Ответ #3 : 16.10.2008, 23:50:51 »
вообще не должно. у меня 44 запроса. 7 пунктов в меню отключил. стало 37. потом снова включил. стало 38 запросов. а в IE та же отладка показывает вообще 34 запроса при любом кол-ве меню.
/* Have a nice day! */
*

dvtimofei

  • Захожу иногда
  • 111
  • 4 / 1
Re: Запрос к БД
« Ответ #4 : 17.10.2008, 18:14:02 »
А что за запрос такой, окуда идет
SELECT oldurl FROM jos_redirection WHERE newurl = 'index.php?option=com_content&id=154&task=view'

?
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

запрос на авторизацию после нажатие на ссылку подробнее

Автор sikvestor

Ответов: 2
Просмотров: 1888
Последний ответ 06.07.2009, 17:21:01
от sikvestor
Запрос авторизации перед каждым просмотром материала

Автор bax

Ответов: 4
Просмотров: 2316
Последний ответ 17.02.2009, 10:25:09
от bax
После сброса пароля суперадмина (SQL-запрос): "Невозможно подключиться к серверу базы данных"

Автор fatalerror

Ответов: 3
Просмотров: 2041
Последний ответ 28.11.2008, 13:28:30
от fatalerror
SQL запрос.... один-к многим что ли...

Автор Lord Glue

Ответов: 1
Просмотров: 2276
Последний ответ 25.09.2008, 23:56:31
от Lord Glue