MIDAV.RU

MIDAV.RU

Учусь делать сайты в свободное время .

Переопределение макетов вывода в Joomla 3

Просмотров: 2873Комментарии: 0
Joomla
Переопределение макетов вывода в Joomla 3

В Joomla 3 появились так называемые макеты вывода , которые выводятся с помощью класса JLayout . С помощью макетов можно выводить какие то небольшие кусочки сайта , используемые в разных местах . Например иконки , теги , кнопка подробнее , пагинация и т.д. Список всех доступных на данный момент макетов можно посмотреть в папке layouts .

Я добавлю для примера вывод рисунка в мой любимый тестовый модуль - последние новости smileИ воспользуюсь для этого макетом вывода изображения для вступительного текста , которое указывается в настройках материала . Файл этого макета расположен по адресу layouts/joomla/content/intro_image.php

Для того чтобы переопределить макет скопируем этот файл в свой шаблон , по адресу \templates\шаблон\html\layouts\joomla\content\intro_image.php . И дальнейшие манипуляции будем проводить уже с этим файлом . Для начала подключим этот макет в файле модуля . Сам вывод модуля естественно тоже переопределим в шаблоне , скопировав файл модуля \modules\mod_articles_latest\tmpl\default.php к себе в шаблон по адресу \templates\шаблон\html\mod_articles_latest\default.php .

Макет вывода в Joomla подключается следующим образом :

echo JLayoutHelper::render("тут путь к файлу макета", "тут нужные макету параметры" ) ;

Откроем файл макета и посмотрим какие параметры нужны ему для вывода изображения

params;
?>
images); ?>
image_intro) && !empty($images->image_intro)) : ?>
float_intro)) ? $params->get('float_intro') : $images->float_intro; ?>
image_intro_caption): echo 'class="caption"' . ' title="' . htmlspecialchars($images->image_intro_caption) . '"'; endif; ?> src="image_intro); ?>" alt="image_intro_alt); ?>" itemprop="thumbnailUrl"/>

Как видим для вывода изображения макету нужен объект статьи , в модуле он располагается в переменной $item . Поэтому нужный код для подключения макета вывода изображиния будет таким :

echo JLayoutHelper::render("joomla.content.intro_image", $displayData = $item );

Как обычно обрежем текст статьи до 100 знаков , и вырежем все html теги . Полный текст файла модуля :



Результат того что получилось :

screen_latest_news_modul_image.jpg
Оставьте комментарий!

grin LOL cheese smile wink smirk rolleyes confused surprised big surprise tongue laugh tongue rolleye tongue wink raspberry blank stare long face ohh grrr gulp oh oh downer red face sick shut eye hmmm mad angry zipper kiss shock cool smile cool smirk cool grin cool hmm cool mad cool cheese vampire snake excaim question


Используйте нормальные имена. Ваш комментарий будет опубликован после проверки.

     

  

Если вы уже зарегистрированы как комментатор или хотите зарегистрироваться, укажите пароль и свой действующий email. При регистрации на указанный адрес придет письмо со ссылкой на ваш персональный аккаунт, где вы сможете изменить свои данные, включая адрес сайта, ник, описание, контакты и т.д., а также подписку на новые комментарии.

(обязательно)