Новости 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 Гость просматривают эту тему.
  • 3 Ответов
  • 1792 Просмотров

Добавление данных в БД
« : 18.08.2008, 14:30:58 »
ХЕЛП! Не пойму в чем дело, надо чтобы из скрипта данные заносились в БД, таблица существует. Как только не пробовал.
Почему может не работать такой запрос в скрипте?

$database->setQuery( "insert into subscribers(id, code, number, email, tel, model) VALUES (NULL,'$code','$number','$email','$tel','$model')" );
*

smart

  • Администратор
  • 6478
  • 1318 / 15
  • Хочешь сделать хорошо — сделай!
Re: Добавление данных в БД
« Ответ #1 : 18.08.2008, 14:38:08 »
Думаю проблема в том, что запрос вы установили, а выполнить его не выполнили. Добавьте после этого кода еще одну строчку:

Код: php
$database->query();

Re: Добавление данных в БД
« Ответ #2 : 18.08.2008, 17:50:14 »
это граничит с шаманством, так как я считал, что конструкция которую я написал это и есть запрос. Но добавив вашу строку, данные начали заноситься в БД :D
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: Добавление данных в БД
« Ответ #3 : 18.08.2008, 18:04:30 »
$database->setQuery() - собственно тело запроса
$database->query() - выполнение запроса
мне кажется что некоторая разница все-таки есть :)
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Как в PhpMyAdmin увеличить максимальный размер при импорте базы данных?

Автор prossvika

Ответов: 14
Просмотров: 42316
Последний ответ 15.01.2012, 12:47:14
от root34
Невозможно подключиться к серверу базы данных

Автор ver

Ответов: 7
Просмотров: 12066
Последний ответ 06.12.2010, 19:41:43
от dedanet
Добавление новостей пользователями

Автор ParaNoid_

Ответов: 2
Просмотров: 4039
Последний ответ 22.05.2010, 09:56:46
от BULA
Синхронизация 2 сайтов с одной базой данных.

Автор Quexx

Ответов: 25
Просмотров: 11324
Последний ответ 23.01.2010, 21:52:44
от SSStylish
Можно автоматизировать добавление контента?

Автор Rojas

Ответов: 2
Просмотров: 2625
Последний ответ 29.10.2009, 01:31:01
от Rojas