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

master-smeta

  • Захожу иногда
  • 298
  • 10 / 0
Здравствуйте. Подскажите пожалуйста такой момент: стоит ли использовать в адаптивном дизайне @import для загрузки стилей для разных экранов?
Например сейчас стили разделены стандартными "блоками" типа
Код
@media (min-width: 480px) and (max-width: 599px){
   ...
}
а сам файл template.css состоит из десятка тысяч строк и чтобы поправить какой-нибудь стиль приходится изрядно "поползать" по файлу.

Мне кажется было бы проще, если стили для каждого экрана будут находиться в отдельном файле типа '480-599.css'.
Но как лучше такие файлы подключать? Можно ли например сделать так:
Код
@media (min-width: 480px) and (max-width: 599px){
   @import url(480-599.css);
}
Будет ли это работать, или нет? Правильно ли так делать, или есть другие варианты?

Я мог бы и сам все узнать, потратив время на тесты и общение с гуглом... Но зачем изобретать велосипед, возможно кто0то его уже изобрел?
*

neogeek

  • Захожу иногда
  • 196
  • 21 / 2
Re: @import стилей для различных экранов
« Ответ #1 : 30.06.2015, 13:58:06 »
Код
@media (min-width: 480px) and (max-width: 599px){
   @import url(480-599.css);
}

Будет ли это работать, или нет? Правильно ли так делать, или есть другие варианты?
нет
можно подключать так
Код
<link rel="stylesheet" type="text/css" media="only screen and (max-device-width: 600px)" href="480-599.css"/>
*

Shustry

  • Moderator
  • 6434
  • 745 / 3
Re: @import стилей для различных экранов
« Ответ #2 : 30.06.2015, 13:59:57 »
Код
<link rel="stylesheet" type="text/css" media="only screen and (max-device-width: 600px)" href="480-599.css"/>

Тут нюанс. Если ресайзить экран, то это работать не будет.
*

master-smeta

  • Захожу иногда
  • 298
  • 10 / 0
Re: @import стилей для различных экранов
« Ответ #3 : 30.06.2015, 14:10:22 »
Код
<link rel="stylesheet" type="text/css" media="only screen and (max-device-width: 600px)" href="480-599.css"/>
Спасибо, вариант интересный, но, как сказал Shustry, "при ресайзе экрана изменений не будет", придется обновлять страницу. Хотя, часто ли мы ресайзим страницы?

Ок, может кто-нибудь еще варианты предложит?
*

neogeek

  • Захожу иногда
  • 196
  • 21 / 2
Re: @import стилей для различных экранов
« Ответ #4 : 01.07.2015, 17:43:40 »
Ну обычно media queries для "адаптива" экраны девайсов делают, а не для ресайза окна браузера.
Как вариант написать скриптец на javascript(jQuery), но при отключенном js не будет работать
Код
jQuery(window).resize(function () {
тут код который исполнится при ресайзе
});
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Потерялась и не открывается папка стилей

Автор Ebelous

Ответов: 3
Просмотров: 2042
Последний ответ 07.02.2024, 19:55:08
от Ebelous
Перекликивание стилей CSS

Автор Gromz

Ответов: 19
Просмотров: 1448
Последний ответ 12.08.2019, 22:05:42
от ProtectYourSite
Как изменить не меняя основных стилей?

Автор wishlight

Ответов: 2
Просмотров: 1629
Последний ответ 14.03.2018, 18:58:53
от wishlight
Как сделать переопределение стилей для syperfish menu?

Автор Panchito

Ответов: 2
Просмотров: 1323
Последний ответ 18.11.2014, 12:47:27
от effrit
Как же все таки найти этот CSS с таблицей стилей шрифта меню?

Автор Kinimania

Ответов: 20
Просмотров: 2200
Последний ответ 30.09.2014, 13:53:33
от Kinimania