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

Martofpain

  • Новичок
  • 3
  • 0 / 0
Привет всем. возникла такая проблема надо добавить на сайт сделанный на Jooml'е таблицу из phpMyAdmin. Я просто новичок в этом и понимаю как это реализовать. Для тест сделал сайт на Open Server, что сначало попробовать там добавить. Может кто объяснить как это сделать и может посоветовать какую нибудь литературу связную с моей проблемой
*

Shustry

  • Гуру
  • 6434
  • 745 / 3
Re: как добавить таблицу из phpMyAdmin?
« Ответ #1 : 28.03.2016, 08:10:47 »
Не совсем понятно, что вы хотите сделать. У вас уже есть таблица в БД и нужно из неё данные вывести куда-то на сайте?
*

arma

  • Завсегдатай
  • 1752
  • 81 / 3
Re: как добавить таблицу из phpMyAdmin?
« Ответ #2 : 28.03.2016, 11:02:07 »
Человек сам не знает, что ему надо, и надо ли вообще.
*

Martofpain

  • Новичок
  • 3
  • 0 / 0
Re: как добавить таблицу из phpMyAdmin?
« Ответ #3 : 28.03.2016, 11:37:35 »
Да, есть таблица и нужно вывести её на сайт, как это можно сделать?
*

Shustry

  • Гуру
  • 6434
  • 745 / 3
Re: как добавить таблицу из phpMyAdmin?
« Ответ #4 : 28.03.2016, 15:02:03 »
Можно октрыть любой новостной модуль Joomla из стандартных, и посмотреть как это там сделано. Вообще, всё просто. Примеры: раз, два, три.
*

arma

  • Завсегдатай
  • 1752
  • 81 / 3
Re: как добавить таблицу из phpMyAdmin?
« Ответ #5 : 28.03.2016, 17:59:23 »
Есть таблица где? В базе, в ехеле на рабочем столе? Больше конкретики и вам подскажут.
*

Martofpain

  • Новичок
  • 3
  • 0 / 0
Re: как добавить таблицу из phpMyAdmin?
« Ответ #6 : 29.03.2016, 05:13:53 »
таблица из базы в phpMyAdmin
*

SeBun

  • BanMaster
  • 4030
  • 259 / 5
  • @SeBun48
Re: как добавить таблицу из phpMyAdmin?
« Ответ #7 : 29.03.2016, 09:24:09 »
Shustry все написал, читайте.
Оказываю услуги по Joomla | Миграция/Обновление | Сопровождение | IT-аутсорсинг | Недорогие домены и хостинг
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: как добавить таблицу из phpMyAdmin?
« Ответ #8 : 29.03.2016, 10:59:12 »
для начала рекомендую подучить мат.часть:
таблица и данные находятся в базе данных
база данных - это хранилище
хранилище управляется специальным сервисом, предназначенного для управления этим хранилищем, такой сервис называется: сервер баз данных
phpMyAdmin - это всего лишь один из многих инструментов работы с хранилищем, в нем нет данных
с помощью инструмента производится управление сервером баз данных, который управляет хранилищем
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Re: как добавить таблицу из phpMyAdmin?
« Ответ #9 : 29.03.2016, 11:55:57 »
И Баба-Яга в виде AlekVolsk окончательно запутала Martofpain-царевича :).
Не будь паразитом, сделай что-нибудь самостоятельно!
*

Shustry

  • Гуру
  • 6434
  • 745 / 3
Re: как добавить таблицу из phpMyAdmin?
« Ответ #10 : 29.03.2016, 12:01:12 »
И Баба-Яга в виде AlekVolsk окончательно запутала Martofpain-царевича :).

Ага. «А потом пришёл Ржевский, и всё опошлил». Из той же серии. ^-^

Martofpain, здесь подробно расписал, как что работает. Только у вас ещё проще, т.к. нужно вывести всю таблицу.

Код: php
$sql = 'select * from #__mytable as mydata'; //запрос будет так примерно выглядеть
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Добавить свои фильтры поиска

Автор denism300

Ответов: 3
Просмотров: 1208
Последний ответ 05.11.2016, 17:14:35
от denism300
Как добавить выбор/загрузку файла в свой модуль в админке?

Автор Absalem

Ответов: 7
Просмотров: 2083
Последний ответ 07.09.2016, 22:48:54
от fsv
Переключение плитка-список. Как добавить куки?

Автор Театрал

Ответов: 2
Просмотров: 1353
Последний ответ 21.02.2016, 21:31:36
от Театрал
Друзья, в чем может быть дело? SQL-запрос в phpMyAdmin

Автор millioner

Ответов: 37
Просмотров: 4693
Последний ответ 01.09.2015, 15:02:51
от Arkadiy
[Решено] PhpMyAdmin: Создать копию строки в таблице

Автор slepoy

Ответов: 1
Просмотров: 2595
Последний ответ 22.11.2014, 14:18:36
от Aleks.Denezh