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

В разных браузерах по-разному получаются разрывы между колонками на сайте.
Прочитав кучу инфы по верстке сделал такой шаблон.

HTML:
Код
<?xml version="1.0" encoding="windows-1251"?>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=windows-1251" />
<title>ТЕСТ</title>
<style type="text/css" media="all">
 
@import "style.css";
 
</style>
</head>
<body>
<div id="head_row">
    <div id="head_left">
        left
    </div>
    <div id="head_center">
        <div class="wrap">
            center
        </div>
    </div>
    <div id="head_right">
        right
    </div>
</div>
<div id="main">
    <div id="content">
            center
    </div>
    <div id="left_col">
        left<br>1
    </div>
    <div id="right_col">
        right
    </div>
</div>
<div id="footer">
    футер
</div>
</body>
</html>
CSS:
Код
html, body {
  width:100%;
  margin: 0px;
  height: 100%;
  min-height: 100%;
  min-width: 600px;
  padding: 0px;
  position:relative;
  background: #ffa;
  font: 0.9em/1.1em Verdana;
}

.wrap {
    margin: 7px;
}

#head_row {
    width: 100%;
    background: #fff;
    height: 20%;
    overflow: hidden;
}

#head_right {
    height: 100%;
    width: 20%;
    background: magenta;
    float: right;
}

#head_left {
    width: 20%;
    height: 100%;
    float: left;
    background: black;
    color: white;
}

#head_center {
    background: blue;
    height: 100%;
    width: 60%;
    float: left;
}

#main {
    background: white;
    width: 100%;
    min-height: 400px;
    overflow:hidden;
}

#content {
    float: left;
    width: 60%;
    background: magenta;
    margin-left: 20%;
    padding-bottom:32767px; margin-bottom:-32767px;
}

* html #content {
      margin-left:10%;
    margin-right:-3px;
}

#left_col {
    float: left;
    background: red;
    width: 20%;
    margin-left:-80%;
      padding-bottom:32767px; margin-bottom:-32767px;
}


#right_col {
    float: right;
    padding-bottom:32767px; margin-bottom:-32767px;
    background: green;
    width: 20%;
   
}

#footer {
    height: 40px;
    background: gray;
}

Суть проблемы видна на скриншотах:
в ie6

в firefox


Помогите, пожалуйста, сделать все div'ы стык в стык.
*

one_more

  • Захожу иногда
  • 139
  • 87 / 3
  • there is no spoon
Начать бороть эту проблему (и любые похожие) я бы посоветовал с "обнулятора" имени Эрика Мейера.
Errare humanum est
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Расположить элементы без класса

Автор AlexB

Ответов: 4
Просмотров: 993
Последний ответ 21.01.2021, 12:47:08
от AlexB
Как улучшить качество своего курсора? Коряво получается почему-то

Автор cantsave

Ответов: 5
Просмотров: 1938
Последний ответ 12.10.2018, 09:06:26
от dynamit
не получается отцентрировать картинки

Автор Cardamon

Ответов: 1
Просмотров: 1110
Последний ответ 19.02.2016, 01:27:29
от dmitry_stas
[Решено] Не получается приделать горизонтальный скрол в нужной позиции

Автор TitanFighter

Ответов: 5
Просмотров: 1110
Последний ответ 13.03.2015, 07:22:26
от AlekVolsk
Как счетчики liveinternet, rambler и др. расположить в ряд а не по вертикали?

Автор yunusov2706

Ответов: 9
Просмотров: 3175
Последний ответ 16.02.2015, 23:51:26
от bogolinr