Руководство по настройщику (кастомайзеру) тем WordPress, часть 2

В этой серии статей мы посмотрим на кастомайзер тем WordPress.

В частности, мы должны понять, что он собой представляет, чем он нам полезен, как интегрировать его в тему, как работать с ним в контексте других тем, а также как реализовать свои собственные секции, параметры и опции.

В данной статье мы продолжим наше обсуждение работы с кастомайзером тем, изучив, как интегрировать его в тему, которая лишена его.

Подождите! Как это: интегрировать кастомайзер в тему? Зачем?

Знаю, знаю – большая часть тем, существующих сегодня на рынке (по крайней мере те из них, которые были заточены под WordPress 3.4), уже включают в себя кастомайзер, потому можно просто начать с ним работу, не задумываясь о его подключении.

На самом деле я бы рискнул сказать, что некоторые читатели этой статьи подключают кастомайзер к своей теме путем простого копирования и вставки, после чего переходят к остальным задачам, которые им требуется реализовать.

Я говорю это без какого-либо намека на пессимизм: я считаю, что таким путем движутся многие разработчики – сначала они ищут решение, которое уже кто-то создал до них, затем применяют его к своей разработке, после чего совершают уже следующие шаги.

В этом нет ничего неправильного – по сути, это основное преимущество открытого исходного кода, — но мы не должны здесь обсуждать, «как скопировать и вставить кастомайзер в тему». Мы должны изучить, как интегрировать его.

Таким образом, в последующих шагах мы обратимся к теме, которая не включает в себя кастомайзер, и затем посмотрим – строка за строкой – как подключить его и начать использовать в своих темах.

Цель состоит в том, чтобы к концу данной статьи вы не только знали, как интегрировать кастомайзер к теме, но и знали, что делает каждый участок соответствующего кода.

Для начала давайте создадим тему

В целях этой статьи мы будем работать с базовой WordPress темой. Исходник будет приведен в конце статьи, а пока давайте постепенно пойдем вперед, и будем шаг за шагом работать над созданием темы.

Обратите внимание на то, что все наши действия являются частью методов разработки тем WordPress, обрисованных в общих чертах в соответствующей статье кодекса.

Во-первых, в своей локальной сборке WordPress создайте директорию wp-content/themes под названием theme-customizer-example. Именно здесь мы и будем работать с нашим основным кодом.

Стилевая таблица

Для начала нам требуется создать стилевую таблицу, чтобы WordPress мог распознать тему в меню «Внешний вид». Назовем ее style.css и добавим к ней специальный комментарий.

К примеру, я использовал для этого следующий код:

/*
Theme Name: Theme Customizer Example
Theme URI: http://github.com/tommcfarlin/theme-customizer-example/
Version: 0.1.0
Description: A basic theme used to demonstrate how to integrate the Theme Customizer into a WordPress Theme.
Author: Tom McFarlin
Author URI: http://tommcfarlin.com
License: GPLv2
License URI: http://www.gnu.org/licenses/gpl-2.0.html
*/

Теперь давайте добавим несколько шаблонов, чтобы как-то обозначить нашу тему.

Шаблон хэдера

Давайте определим шаблон хэдера. Сделать это можно, создав файл header.php и добавив в него следующий код:

<!DOCTYPE html>
<html <?php language_attributes(); ?>>
    <head>
        <meta charset="UTF-8">
        <link rel="profile" href="http://gmpg.org/xfn/11" />
        <link rel="pingback" href="<?php bloginfo( 'pingback_url' ); ?>" />
        <title><?php wp_title( '' ); ?></title>
        <?php wp_head(); ?>
    </head>
    <body <?php body_class(); ?>>
 
        <div id="header">
            <h1>
                <?php bloginfo( 'title' ); ?>
            </h1>
            <h2>
                <?php bloginfo( 'description' ); ?>
            </h2>
        </div><!-- /#header -->

Ничего сложного, верно? Мы определили элемент head, открывающий тег body и простой элемент div, что будет использоваться для представления хэдера.

Затем мы включили h1 для отображения заголовка блога, а также h2 для вывода описания блога.

Шаблон главной страницы

В данной серии статей мы будем работать с отдельным шаблоном для вывода контента. В частности, все, что мы будем выводить на экран, будет делаться через index.php.

Это будет простой шаблон, отображающий хэдер, футер и строку текста:

<?php get_header(); ?>
 
    <div id="content">
        This is the content.
    </div><!-- /#content -->
 
<?php get_footer(); ?>

Возможно, это самый простой шаблон из всех, не так ли?

Шаблон футера

Мы почти закончили – нам осталось только ввести базовый шаблон футера, в котором мы будем выводить, скажем, сообщение о том, что все права защищены.

Добавим следующий код:

        <div id="footer">
            &copy; <?php echo date( 'Y' ); ?> <?php bloginfo( 'title' ); ?> All Rights Reserved
        </div><!-- /#footer -->
 </body>
</html>

Здесь мы выводим копирайт, дату создания блога, а также его название.

Не забудьте скриншот!

Обратите внимание на то, что если вы хотите, чтобы у вашей темы было красивое изображение в консоли, вы должны добавить файл screenshot.png в корневую папку с темой.

tcx-theme

Разрешение должно быть 300x225 (либо в два раза больше для HiDPI дисплеев). Как вы видите в примере выше, я решил использовать изображение из моего любимого комикса.

Естественно, вы можете выбрать какое-либо другое изображение – либо вообще отказаться от него.

Первый взгляд на нашу тему

На данный момент мы готовы взглянуть на нашу тему. Поэтому давайте активируем ее в своей консоли, после чего мы увидим что-то подобное:

tcx-basic-home-screen

Как я и говорил – в такой теме нет ничего сложного, но она поможет нам двигаться вперед.

И вот одно замечание: кастомайзер тем уже встроен во все современные стандартные темы. Правда, вы не сможете изменить все аспекты темы. Давайте все же протестируем его.

Запуск кастомайзера тем

В меню «Внешний вид» в консоли щелкаем по пункту «Темы», после чего жмем на ссылку «Настроить», которая представлена сразу под описанием вашей темы.

Вы перейдете к кастомайзеру:

tcx-customizer

Раскроем секцию Site Title & Tagline (Заголовок и описание сайта) и настроим контент каждого из представленных полей. После ввода текста вы увидите свои изменения в окне предварительного просмотра.

Круто, не правда ли?

Однако это не все!

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

Но на данный момент у вас должна быть необходимая основа: тема, с которой мы будем работать дальше, а также базовая функциональность кастомайзера.

В следующей статье мы еще глубже погрузимся в работу с кастомайзером. На данный момент вы можете получить рабочую копию темы из репозитория GitHub.

В следующей статье…

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

В следующей статье мы погрузимся в секции, параметры настройки, а также средства управления, которые относятся к кастомайзеру. Это поможет нам сколотить прочный фундамент, начиная с которого мы уже пойдем дальше создавать свои собственные возможности для кастомайзера.

Источник: wp.tutsplus.com

Блог про WordPress
Комментарии: 2
  1. Волшебник

    Кастомайзер — хорошая штука, которая позволяет увидеть все изменения на лету. Но почему-то почти никто его не использует при создании тем. И обычно в кастомайзере можно настроить только незначительные элементы типа названия сайта, цвет фона и всё! Смысла ноль. И это даже в дефолтных темах такой плохой пример подают.

    Ситуация такова, что создатели тем предпочитают создавать отдельную страницу или раздел с настройками для своих тем, а не пользоваться кастомайзером.

    1. Дмитрий (автор)

      И это не совсем правильно. Такие страницы настроек порой отпугивают пользователей, поскольку им надо разбираться, что делает та или иная опция, тратить свое время на изучение, тестирование и т.д. Плюс ко всему, не все опции работают как полагалось. Помню, как ставил одну из таких тем, она предполагала подключение google fonts путем ввода названия шрифта, но ввод названия шрифта ни к чему не приводил. Ничего не менялось. Пытался и код вводить, и так и сяк пробовал, ничего. Так и не разобрался, в чем был косяк, потратил лишь свое время. Еще был случай, когда настройки не сохранялись с первого раза. Приходилось щелкать несколько раз, чтобы тема их запомнила, и при каждом новом заходе на эту страницу все настройки опять сбрасывались в дефолтные. И это — одна из free тем от какого-то поставщика премиум тем. Вот так и покупай темы.

Добавить комментарий

Получать новые комментарии по электронной почте.