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

Efanych

  • Глобальный модератор
  • 4683
  • 644 / 0
  • Меняю свою жизнь на 360°!
Изображение вставлено прямо в текст (хорошо хоть структура одинаковая...).
Это блог категории, таких на странице куча. Картинку (а лучше даже ссылку, в которую картинка обёрнута) нужно перенести каждую в свой блок .image, который находится в том же блоке .item, что и картинка...

Цитировать
<div class="item">
    <h2><h2>
    <div class="image"></div> /* это я вписал, чтоб в него переносить */
    <div class="item-text">
        <p><a><img /></a></p>
    </div>

Ну вот и вопрос. Как?
С JS не дружу, методом тыка не получилось...
   
Создание сайтов, шаблонов, помощь в решении проблем.
*

umbabaraumba

  • Живу я здесь
  • 2415
  • 153 / 1
  • если помог можете поставить +
Re: Перенести изображение с помощью JS
« Ответ #1 : 15.11.2014, 20:02:40 »
Примерно так, но это jQuery
Errare humanum est
Ubuntu по-русски
Пишу не сложные модули и компоненты, не дорого но не срочно
*

Efanych

  • Глобальный модератор
  • 4683
  • 644 / 0
  • Меняю свою жизнь на 360°!
Re: Перенести изображение с помощью JS
« Ответ #2 : 15.11.2014, 20:08:51 »
Как вырезать и перенести, я уже знаю.
Просто тут не получится указать класс блока, куда переносить, что-то типа такого нужно, но как правильно не знаю...

Цитировать
jQuery('.item-text p a').appendTo(jQuery(this).parent().parent('.image'));
Создание сайтов, шаблонов, помощь в решении проблем.
*

zomby6888

  • Завсегдатай
  • 1473
  • 171 / 3
Re: Перенести изображение с помощью JS
« Ответ #3 : 15.11.2014, 20:24:59 »
без jquery
Код: javascript
var elements = document.getElementsByClassName('item-text');
for (i=0; i< elements.length ; i++) {
    var elem = elements[i].getElementsByTagName('img')[0];
    var image = elements[i].parentNode.getElementsByClassName('image')[0];    
    image.appendChild(elem);    
}
интернет-блог: http://websiteprog.ru
*

icom

  • Давно я тут
  • 830
  • 202 / 4
Re: Перенести изображение с помощью JS
« Ответ #4 : 15.11.2014, 20:28:48 »
Код: javascript
jQuery('.item').each(function(){
jQuery('.image', this).append(jQuery(this).find('a:has(img)'));
});
« Последнее редактирование: 15.11.2014, 20:32:14 от icom »
*

Efanych

  • Глобальный модератор
  • 4683
  • 644 / 0
  • Меняю свою жизнь на 360°!
Re: Перенести изображение с помощью JS
« Ответ #5 : 15.11.2014, 20:40:29 »
без jquery
Код: javascript
var elements = document.getElementsByClassName('item-text');
for (i=0; i< elements.length ; i++) {
    var elem = elements[i].getElementsByTagName('img')[0];
    var image = elements[i].parentNode.getElementsByClassName('image')[0];   
    image.appendChild(elem);     
}
zomby6888, не заработало, но не анализировал, почему.
Вариант icom отлино сработал!
 *DRINK*
Создание сайтов, шаблонов, помощь в решении проблем.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Перенести сайт с Magento на Joomla как можно быстрее?

Автор MasterFloma

Ответов: 6
Просмотров: 1265
Последний ответ 28.04.2018, 06:30:30
от Taatshi
Загрузка материалов с помощью CDN

Автор Lovrentiy

Ответов: 4
Просмотров: 1274
Последний ответ 13.04.2015, 16:25:06
от Lovrentiy
Как с помощью jquery или javascript узнать зашол ли некий обьект за скрол или нет?

Автор kontrast

Ответов: 0
Просмотров: 1444
Последний ответ 26.02.2013, 18:45:35
от kontrast