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

Barmunk

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
index.php можно заблочить?
« : 11.05.2010, 00:53:15 »
Невозможно уже ждать когда Яндекс сделает 301 редирект с не чпу ссылок на нормальные. Прошло уже 2 месяца, только половина нормальная стала, а всего-то страниц чуть больше 100... Ктонить пробовал после чпу блочить все страницы начинающиеся с индекс.пхп? Нормально Яндекс к этому отнесется?
*

valagoff

  • Давно я тут
  • 984
  • 110 / 0
Re: index.php можно заблочить?
« Ответ #1 : 11.05.2010, 00:58:48 »
1.Проверьте действительно ли сервер отдает 301 редирект при обращении к странице по старому URL
2.Зачем блочить index, когда можно блочить строку запроса?
*

Barmunk

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
Re: index.php можно заблочить?
« Ответ #2 : 11.05.2010, 01:27:54 »
1.Проверьте действительно ли сервер отдает 301 редирект при обращении к странице по старому URL
2.Зачем блочить index, когда можно блочить строку запроса?
Да, отдает 301 редирект, как пример: http://www.bertal.ru/index.php?url=http%3A%2F%2Ftawatec.su%2Findex.php%3Fpage%3Dshop.product_details%26category_id%3D19%26flypage%3Dflypage.tpl%26product_id%3D60%26option%3Dcom_virtuemart%26Itemid%3D71&ar=94615#h
Тайтл в выдаче еще не сменен, урл не преобразован... Просто уже не возможно столько ждать...

Всмысле строку запроса? Объясните пожалуйста.
*

valagoff

  • Давно я тут
  • 984
  • 110 / 0
Re: index.php можно заблочить?
« Ответ #3 : 11.05.2010, 01:49:07 »
Всмысле строку запроса? Объясните пожалуйста.
в файле robots.txt
Код
Disallow: /*?*
*

Barmunk

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
Re: index.php можно заблочить?
« Ответ #4 : 11.05.2010, 02:12:34 »
в файле robots.txt
Код
Disallow: /*?*
Отлично! Спасибо!
*

Barmunk

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
Re: index.php можно заблочить?
« Ответ #5 : 12.05.2010, 01:30:38 »
Еще один вопросик...

Есть на сайте вложения папок вида:
 
1. Компоненты
1.2 Плагин1
1.3 Плагин2
1.4 Плагин3
1.5 Плагин4
 
Мне нужно чтобы из всех папок индексировалось только плагин2, остальные были заблокированы роботс.
 
Какой из вариантов правильный? или не какой?
 
User-agent: *
Disallow: /компоненты/Плагин1/
Disallow: /компоненты/плагин3/
Disallow: /компоненты/плагин4/
Тоесть просто перечислить все те папки которые нужно заблочить, кроме той, которая нужна.
Минус этого что придется делать в дальнейшем огромный список того что надо заблочить...
 
User-agent: *
Disallow: /компоненты/
Allow: /компоненты/плагин2/
Правильно ли так будет?
*

Haz86

  • Новичок
  • 4
  • 0 / 0
Re: index.php можно заблочить?
« Ответ #6 : 03.06.2010, 17:00:58 »
Вопрос такой:
В выдаче яндекса выходит дубль главной страницы - сайт.ру/index.php
Каким образом лучше исключить эту страницу из индекса? В роботс.тхт прописать:
User-agent: *
Disallow: /index.php

Или есть какой-то другой способ?
И не выкинет ли Яндекс из индекса другие страницы типа:
/index.php?option=com_content&task=blogsection&id=2&Itemid=11
*

Darkick

  • Завсегдатай
  • 1142
  • 239 / 1
Re: index.php можно заблочить?
« Ответ #7 : 03.06.2010, 20:01:57 »
И не выкинет ли Яндекс из индекса другие страницы типа:
/index.php?option=com_content&task=blogsection&id=2&Itemid=11
выкинет.
я руками сделал модификацию, чтобы с чистого index.php редиректило в корень.
Код: php
if (!$_POST && ($_SERVER['REQUEST_URI'] == '/index.php')) {
header('Location: http://'.$_SERVER['SERVER_NAME'].'/', true, 301);
die();
}
добавить в начало index.php


...
Какой из вариантов правильный? или не какой?
...
первый. директивы Allow нет.
*

Haz86

  • Новичок
  • 4
  • 0 / 0
Re: index.php можно заблочить?
« Ответ #8 : 04.06.2010, 13:02:00 »
Darkick, спасибо! :D  Помогло! Осталось посмотреть как Яндекс отнесется к этому  ^-^
*

style.ilya

  • Осваиваюсь на форуме
  • 49
  • 0 / 0
  • http://dreambikes.ru
Re: index.php можно заблочить?
« Ответ #9 : 30.06.2010, 00:18:28 »

я руками сделал модификацию, чтобы с чистого index.php редиректило в корень.
Код: php
if (!$_POST && ($_SERVER['REQUEST_URI'] == '/index.php')) {
header('Location: http://'.$_SERVER['SERVER_NAME'].'/', true, 301);
die();
}
добавить в начало index.php

Спасибо. Все работает. До этого я прописывал такие строки в .htaccess:

Код
RewriteCond %{THE_REQUEST} ^[A-Z]{3,9}\ /index\.php\ HTTP/
RewriteRule ^index\.php$ http://сайт.ru/ [R=301,L]

И после этого при нажатии кнопки купить в VirtueMart показывалась просто белая страница.

Вообще, это важная вещь, редирект с index.php на корень сайта ?
*

Webb

  • Захожу иногда
  • 304
  • 19 / 2
  • rusinmd
Re: index.php можно заблочить?
« Ответ #10 : 01.07.2010, 02:16:11 »


Вообще, это важная вещь, редирект с index.php на корень сайта ?

вам нужны дубли?
*

rubasket

  • Захожу иногда
  • 346
  • 13 / 1
  • RuBasket.com
Re: index.php можно заблочить?
« Ответ #11 : 01.07.2010, 06:40:09 »
в файле robots.txt
Код
Disallow: /*?*
таким макаром ты все компоненты ,не имеющие роута, заблокируешь
Только я знаю,что могу (C) Джон Локк 
Why him ?Mmm? What  about me? БЕНЖАМИН Л
*

style.ilya

  • Осваиваюсь на форуме
  • 49
  • 0 / 0
  • http://dreambikes.ru
Re: index.php можно заблочить?
« Ответ #12 : 01.07.2010, 13:36:49 »
вам нужны дубли?

Да хрен его знает ) я только недавно узнал что сайт с www и без поисковики могут считать как два.

P.S. сегодня Яндекс Метрика пишет, что код счетчика установлен не на всех страницах. Хм..это может быть связяно с тем, что я ввел это правило с Index.php? Правда сама метрика глючит..пишет ошибку..
*

whois

  • Осваиваюсь на форуме
  • 18
  • 1 / 0
Re: index.php можно заблочить?
« Ответ #13 : 03.08.2010, 14:57:03 »

Какой из вариантов правильный? или не какой?
 
User-agent: *
Disallow: /компоненты/Плагин1/
Disallow: /компоненты/плагин3/
Disallow: /компоненты/плагин4/
Тоесть просто перечислить все те папки которые нужно заблочить, кроме той, которая нужна.
Минус этого что придется делать в дальнейшем огромный список того что надо заблочить...
 
User-agent: *
Disallow: /компоненты/
Allow: /компоненты/плагин2/
Правильно ли так будет?
первый. директивы  нет.

Директива Allow есть! Читаем внимательно! http://help.yandex.ru/webmaster/?id=996567#996571 Только надо писать ее перед Disallow

User-agent: *
Allow: /компоненты/плагин2/
Disallow: /компоненты/
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Htaccess и редирект с index.php на без index.php

Автор PavelK

Ответов: 2
Просмотров: 4419
Последний ответ 11.05.2023, 14:31:40
от PaLyCH
Каким плагином можно закрыть внешние ссылки?

Автор gorbi_U

Ответов: 4
Просмотров: 2682
Последний ответ 25.02.2023, 02:29:35
от olegon
Можно ли скрывать SEO текст?

Автор kiev

Ответов: 16
Просмотров: 2486
Последний ответ 13.08.2020, 11:59:57
от zikkuratvk
/index.php?option=com.... как закрыть от индексации подобные страницы?

Автор roma_sanbl4

Ответов: 2
Просмотров: 1380
Последний ответ 20.09.2017, 10:33:53
от roma_sanbl4
Пустым или не пустым должен быть index.html в папке шаблона?

Автор borro

Ответов: 1
Просмотров: 1100
Последний ответ 07.03.2017, 14:18:31
от effrit