Новости 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 Ответов
  • 1456 Просмотров
*

easy_simple

  • Осваиваюсь на форуме
  • 49
  • 0 / 0
Что то ужаснулся я когда включил режим отладки..   >:(     208 запросов

Правда мало что в этом понимаю, но чуйка мне подсказывает что это много запросов к БД и к тому же 36 повторяющихся  !

Стоит JS покупная, Jcomment, jslogin + плагин для JS покупной, модуль табов, модуль выезжающего модуля, всё либо бесплатное либо покупное.

Понмаю что запросов никак не избежать, но возможно ли что то сделать с повторяющимися запросами?

« Последнее редактирование: 26.11.2014, 17:40:30 от easy_simple »
*

easy_simple

  • Осваиваюсь на форуме
  • 49
  • 0 / 0
А ещё вот в сервисе для проверки нагрузки http://loaddy.com/result/2462    94 неуспешных 238 успешных ответа за 1,5 минуты при эмуляции посещения 50 человек...

остальные сайты проверяю в этом же сервисе, даже Joomla 2.5 на сайте котором много всякого хлама уже и то результаты на поряяядок выше в большинстве случаев вообще ошибок нету    >:( >:( >:( >:(
« Последнее редактирование: 26.11.2014, 17:41:59 от easy_simple »
*

easy_simple

  • Осваиваюсь на форуме
  • 49
  • 0 / 0
Прикол ваще а вот результаты сайта на Joomla 2,5   http://loaddy.com/result/477057726/    0 не успешных ответов и 758 успешных...   и в режиме отладки 10 sql запросов..
*

neo85r

  • Захожу иногда
  • 93
  • 10 / 0
  • Ускорение сайтов
Общее количество запросов весьма косвенно связано с производительностью.
Хотя число 208 это очень прилично.
Если MySQL находится на отдельном сервере, есть накладные расходы на передачу данных по сети. Если localhost - затрат нет.
Однако отдельный сервер под БД может быть лучше по причине его оптимизации (а также настройки мускула).
В данной ситуации вначале следует понять - на что уходят 406мс - либо тормозит мускул, либо сеть (если не localhost, то скорее всего половину отжирает сеть).
36 повторяющихся запросов означает несовершенство кода, хотя мускул при включенном кеше достает повторяющиеся результаты молниеносно.
Всю архитектуру не перекроить, поэтому подход следующий: смотрим самые тормозные запросы и пытаемся их ускорить - построением индексов, переписыванием запросов.
Эта работа называется оптимизацией запросов.
Повторяющиеся запросы возможно убрать только если знать php и заняться перепрограммированием части компонентов.
Также по возможности включаем кеш Joomla.
Если ничего не помогает, нанимаем программиста и/или меняем хостинг.
Волшебных решений (галочка "ускоряем" работу с БД) нет.
*

voland

  • Легенда
  • 11026
  • 588 / 112
  • Эта строка съедает место на вашем мониторе
Волшебных решений (галочка "ускоряем" работу с БД) нет.
Ну не совсем так, даже если не брать включение кэширования, то можно запросы пропускать через memcache, стандартно в конфиге прописывается.
Если речь о своем сервере, можно также попробовать настроить размер кэшей самого мускуля и расположение папки с временными файлами.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Как лучше сделать при заполнении тегов? (SEO оптимизация)

Автор Zhanadil1509

Ответов: 9
Просмотров: 1434
Последний ответ 22.08.2017, 07:40:20
от Zhanadil1509
Оптимизация интернет-магазина + отзывчивость сайта

Автор Strikerus

Ответов: 0
Просмотров: 1141
Последний ответ 09.12.2016, 12:44:28
от Strikerus
сжатие svg оптимизация под Google пейджспид

Автор AdWeb

Ответов: 1
Просмотров: 1692
Последний ответ 28.11.2016, 21:57:34
от ProtectYourSite
Нужна помощь по снижению колличества запросов

Автор Stasweb

Ответов: 6
Просмотров: 1341
Последний ответ 09.08.2016, 16:01:05
от News_N
Распределение запросов по страницам сайта

Автор AndJy

Ответов: 8
Просмотров: 1081
Последний ответ 02.08.2016, 17:44:47
от AndJy