Categories: Мнение

Построение блоков без JavaScript: тестирование ACF, Block Lab и Lazy Blocks

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

Есть третий способ: плагины, которые создают блоки для вас из набора определенных настраиваемых полей с шаблоном для управления отображением блоков во внешнем интерфейсе. Три самых популярных варианта для этого включают: Block Lab , ACF (Advanced Custom Fields) и Lazy Blocks .

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

Для каждого плагина я продемонстрирую

  • как создать Fieldgroup,
  • как создать шаблон для веб-интерфейса и
  • как использовать блоки для создания страницы команды.

Я использовал Local by Flywheel в качестве локального инструмента разработки. Тестовый сайт работал на WordPress 5.1.1 , Gutenberg 5.4 и Business Theme от WordPress.com.

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

Создание группового блока с помощью Block Lab

Члены команды XWP создали Block Lab, и он доступен как бесплатный плагин с коммерческой версией. Сначала я использовал Block Lab, установил плагин, а затем начал новый блок.

Следующим шагом будет настройка шаблона блока.

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

Чтобы создать шаблон, я открыл редактор кода, создал файл block-team-member.php и добавил HTML + и минимальный PHP для ссылки на поля.

1 <h2>
2 <?php block_field( 'first-name' );?>
3 <?php block_field( 'last-name' );?>
4 </h2>
5 <p><img class="teamphoto" src="<?php block_field( 'picture' ); ?>"
6  alt="<?php block_field( 'first-name' );?>
7 <?php block_field( 'last-name' );?> " width="150" style="float:left;padding:4px;margin;2px;"/>
8 <?php block_field( 'short-bio' ); ?></p>
9
10 <p><em>You can reach <?php block_field( 'first-name' );?></em>
11 <br/>via email <span><a href="mailto:<?php block_field( 'email-address' ); ?>">
12 <?php block_field( 'email-address' ); ?></a></span>
13  or <br/>
14 via phone: <span><?php block_field( 'extension' ); ?></span></p>

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

  • Ставлю иконку на человека,
  • Выбрал «Элементы макета» в качестве категории и
  • Добавлены ключевые слова «член команды, команда»

Посмотрим, как это работает.

Я добавил новую страницу под названием « Знакомство с нашей командой Block Lab» и добавил членов команды, используя блок «Член команды».

А пока я решил, что вся информация должна быть заполнена в границах редактора блоков. Во время настройки полевой группы у меня также была возможность отображать элементы управления формой на вкладке «Параметры блока» на боковой панели. На данный момент я определил, что это просто личные предпочтения. Как только вы щелкнете за пределами блока, форма исчезнет, ​​и блок будет отображен аналогично его внешнему виду.

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

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

Когда я хочу выключить тему, я все равно хотел бы сохранить блок и макет блока на моем сайте, поэтому мне нужно обязательно скопировать папку блоков в каталог новой темы. Другой способ описан в документации по Blocklab на Github . Он предлагает два фильтра для изменения местоположения шаблона по умолчанию:

«Чтобы использовать другой шаблон в своей теме, используйте фильтр block_lab_override_theme_template ($ theme_template). Чтобы использовать другой шаблон вне вашей темы (например, в плагине), используйте фильтр block_lab_template_path ($ template_path) ».

Это было довольно легко настроить, даже если вы не являетесь разработчиком PHP, вы, вероятно, можете использовать одну функцию PHP block-field () и обязательно ссылаться на правильные имена полей.

Block Lab, по сути, предоставляет вам метод для создания полей и настройки свойств блока на одном экране, а затем вам необходимо добавить соответствующий шаблон блока в папку / blocks / в каталоге вашей темы. Это довольно просто.

Создание группового блока с помощью ACF 5.8

ACF (Advanced Custom Fields) версии 5.8 вышел с конструктором блоков (доступен только в версии Pro). Для своего теста я использовал ACF 5.8 RC 1. Финальная версия уже доступна. Эллиот Кондон – автор плагина, первая версия которого была выпущена в 2011 году. Плагин превратился в чрезвычайно популярный инструмент разработчика как для фрилансеров, так и для агентств, и его установили более 1 миллиона раз.

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

^

Это административный вид группы полей «Член команды».

^

Как мне превратить это в блок? Документация достаточно обширна. Примечание. В этом тесте я пошел в несколько ином порядке…

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

Я использовал два файла. Во-первых, мне нужно было зарегистрировать блок в functions.php моей темы. Для кода рендеринга шаблона / блока я использовал content-block-team-member.php, который также хранится в папке активной темы.

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

И так, давайте напишем код блока на PHP

Первый фрагмент – это регистрация блока. Я дал ему имя, заголовок, описание, указал на шаблон рендеринга, дал ему категорию, значок и несколько ключевых слов, по которым производитель контента может найти блок в модуле вставки блоков. Я прокрутил файл functions.php своей темы до конца и добавил этот фрагмент:

1 function register_acf_blocks() {
2    // register a team member block.
3    acf_register_block(array(
4        'name'              => 'acf-team-member',
5        'title'             => __('ACF Team Member'),
6        'description'       => __('A custom team member block created via ACF 5.8'),
7        'render_template'   => 'content-block-team-member.php',
8        'category'          => 'formatting',
9        'icon'              => 'admin-comments',
10        'keywords'          => array'team member''team' ),
11    ));
12 }
13 // Check if function exists and hook into setup.
14 if( function_exists('acf_register_block') ) {
15    add_action('acf/init''register_acf_blocks');
16 }

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

В следующем разделе я создал шаблон рендеринга блока. Имя файла должно соответствовать атрибуту «render_template» в приведенном выше тексте, то есть « content-block-team-member.php ».

Я также просто следил за документацией ACF и только изменил несколько значений и обновил код дисплея.

1 <pre class="wp-block-syntaxhighlighter-code"><?php
2 // create id attribute for specific styling
3 $id 'team-member' $block['id'];
4
5 // create align class ("alignwide") from block setting ("wide")
6 $align_class $block['align'] ? 'align' $block['align'] : '';
7
8 // Load values and asigning defaults for the block fields.
9 $short_bio = get_field('short_bio') ?: 'the short bio goes here... ';
10 $first_name = get_field('first_name') ?: 'First Name';
11 $last_name = get_field('last_name') ?: 'Last Name';
12 $image = get_field('picture');
13 $email_address = get_field('email_address');
14 $extension = get_field('extension');
15 ?>
16
17 <div>" class="team-member ">
18        <h2> </h2>
19    <blockquote class="team-member-blockquote">
20    <img class="teamphoto">" alt="" alt="  " width="150" style="float:left;padding:4px;margin;2px;"/>
21        <span class="team-member-short-bio"></span>
22        <br />
23        <span class="team-membe-extension"></span><br />
24        <span class="team-membe-email-address">
25        </span>
26    </blockquote>
27 </div>
28 </pre>

Когда я начал с Fieldgroup, мне нужно было вернуться и убедиться, что группа связана с только что зарегистрированным блоком. Под экраном группы полей я создал правило для местоположения: оно должно читать: «Показать эту группу полей, если блок равен члену группы ACF».

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

Это был интересный опыт. Вы можете использовать форму в разделе редактора для ввода данных. Другой вариант – ввести данные в поля формы, доступные на боковой панели, и вы увидите обновление блока в реальном времени. Вы можете переключаться между двумя методами, но нажимая кнопку «Перейти к редактированию» или «Перейти к предварительному просмотру», в зависимости от того, какой метод вы используете прямо сейчас.

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

Создание группового блока с ленивыми блоками

Третий плагин в этом тесте называется «Lazy Blocks» Никитой из nkdev.info, той же команды, которая также опубликовала коллекцию блоков GhostKit .

Это не только позволяет мне хранить информацию в post_content, но и есть возможность хранить ее в таблице post_meta.

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

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

Мне не нужно было добавлять какой-либо код в файл functions.php моей темы, и мне не нужно было создавать дополнительные файлы с моим кодом шаблона.

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

Я скопировал / вставил тот же код во вкладку «Редактор HTML», чтобы я мог видеть отображение внешнего интерфейса под полями формы.

Давай воспользуемся этим.

Кажется, это работает. Было немного неловко, что форма не исчезла, когда я снял выделение с блока. В редакторе он занимает много места. Хотя я хотел, чтобы члены команды находились в блоке из двух столбцов, мне не удалось перетащить два блока в блок столбцов. Я упомянул об этом в своей теме поддержки, и nK ответил: «… скрытие элементов управления, когда блок не выбран, – это хорошая функция, которая уже добавлена ​​в блоки ACF и скоро будет добавлена ​​в ленивых блоках». Вот и все – в свое время.

Вывод: сложный, развитый или простой.

ACF 5.8 имеет очень надежную функцию построения блоков, и каждый, кто использовал этот плагин для создания сайтов, будет очень рад иметь возможность создавать динамические блоки для своих клиентов. Он хорошо продуман, и разработчики с любым набором навыков быстро начнут работать.

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

На данный момент только версия ACF 5.8 Pro поставляется с функцией построения блоков. Кондон рассматривает возможность сделать его отдельным плагином . (Посмотрите, что думают Twitteratti об этой идее…)

Block Lab находится на ранней стадии разработки. Ему удается абстрагироваться от большей части блочной архитектуры и сокращает объем кода, который необходимо написать. Документация очень полезна. Шаблон хранится в отдельном файле, и его необходимо поддерживать вместе с остальными файлами темы. Если бы мы в моей компании использовали его для любого из наших проектов, мы бы сохранили файл шаблона с одним из наших вспомогательных плагинов, чтобы наши клиенты могли переключать темы без потери содержимого и отображения блоков, созданных с помощью Block Lab.

Версия Pro может похвастаться дополнительными функциями, такими как поля повторителя, импорт / экспорт блоков, поля пользовательских объектов, поле карты и многие другие функции блоков.

XWP – это агентство, работающее с корпоративными клиентами на хостинге WordPress.com VIP и другими корпорациями. Члены их команды вносят свой вклад в другие большие идеи в области WordPress, включая Customizer , AMP и Tide . Я ожидаю, что плагин останется и вырастет с Gutenberg Phase 2 до надежной системы для разработчиков сайтов, агентств и разработчиков тем.

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

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

Единственная оговорка: мне не удалось выяснить, кто стоит за nkdev.info и именем Никита. Сайт только показывает, что это молодая компания, но не более того. Если вы используете плагин, убедитесь, что у вас есть план Б на тот случай, если разработчики откажутся от плагина до его запуска.

ACF 5.8 довольно сложен; Block Lab – очень гибкий и полусложный; и Lazy Blocks имеют адекватное название и наиболее просты в использовании. Ни один из них не позволяет вам обойтись без написания кода, поскольку каждый блок требует вывода на экран в HTML.

Сообщите мне, что вы думаете об этих трех плагинах для создания блоков. Кроме того, если вы нашли другой плагин, который позволяет создавать блоки, не заходя в Javascript, я хочу знать об этом! Делитесь своими мыслями и открытиями в комментариях!

 

writer

Recent Posts

Плагин Delete Me для WordPress помогает владельцам веб-сайтов предоставить право на забвение GDPR

Поскольку до крайнего срока соблюдения GDPR ЕС осталось всего 178 дней , многие владельцы сайтов…

2 года ago

Команда Gutenberg наращивает юзабилити-тестирование в WordCamp US

Команда Gutenberg создаст станцию ​​тестирования удобства использования в WordCamp US, где посетители смогут принять участие…

2 года ago

Плагин распространителя теперь в бета-версии: новое решение для синдикации контента WordPress от 10up

Сегодня компания 10up опубликовала предварительную версию своего плагина Distributor , нового решения для синдикации контента…

2 года ago

Gutenberg 1.8 добавляет большую расширяемость для разработчиков плагинов

На этой неделе был выпущен Gutenberg 1.8 с несколькими заметными улучшениями, которые предоставят разработчикам плагинов…

2 года ago

Gutenberg 15.5 представляет экспериментальную поддержку разметки сетки

На этой неделе был выпущен Gutenberg 15.5 с новыми функциями и улучшениями возможностей полнофункционального редактирования…

2 года ago

DesktopServer 3.8.4 включает подарок сообществу

DesktopServer выпустил версию 3.8.4 своего программного обеспечения для локальной разработки. Эта версия включает в себя…

2 года ago