Настройка Shopify Metafields для кастомных полей

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

Разработка и обслуживание любых видов сайтов:

Информационные сайты или веб-приложения
Сайты визитки, landing page, корпоративные сайты, онлайн каталоги, квиз, промо-сайты, блоги, новостные ресурсы, информационные порталы, форумы, агрегаторы
Сайты или веб-приложения электронной коммерции
Интернет-магазины, B2B-порталы, маркетплейсы, онлайн-обменники, кэшбэк-сайты, биржи, дропшиппинг-платформы, парсеры товаров
Веб-приложения для управления бизнес-процессами
CRM-системы, ERP-системы, корпоративные порталы, системы управления производством, парсеры информации
Сайты или веб-приложения электронных услуг
Доски объявлений, онлайн-школы, онлайн-кинотеатры, конструкторы сайтов, порталы предоставления электронных услуг, видеохостинги, тематические порталы

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

Предлагаемые услуги
Показано 1 из 1 услугВсе 2065 услуг
Настройка Shopify Metafields для кастомных полей
Простая
от 1 рабочего дня до 3 рабочих дней
Часто задаваемые вопросы

Наши компетенции:

Этапы разработки

Последние работы

  • image_website-b2b-advance_0.png
    Разработка сайта компании B2B ADVANCE
    1262
  • image_web-applications_feedme_466_0.webp
    Разработка веб-приложения для компании FEEDME
    1171
  • image_websites_belfingroup_462_0.webp
    Разработка веб-сайта для компании БЕЛФИНГРУПП
    874
  • image_ecommerce_furnoro_435_0.webp
    Разработка интернет магазина для компании FURNORO
    1094
  • image_crm_enviok_479_0.webp
    Разработка веб-приложения для компании Enviok
    831
  • image_bitrix-bitrix-24-1c_fixper_448_0.png
    Разработка веб-сайта для компании ФИКСПЕР
    851

Настройка Shopify Metafields для кастомных полей

Metafields — механизм расширения стандартной модели данных Shopify произвольными полями без разработки приложения. Доступны для продуктов, вариантов, коллекций, клиентов, заказов, страниц, блогов и магазина в целом.

Концепция namespace и key

Каждое метаполе идентифицируется парой namespace.key. Namespace — логическая группа (обычно имя приложения или домен данных), key — конкретное поле:

  • custom.delivery_days — кастомное поле «Срок доставки»
  • specifications.weight_net — характеристики, вес нетто
  • seo.canonical_override — SEO-оверрайды
  • loyalty.points_multiplier — поля программы лояльности

Стандартные namespace'ы Shopify: descriptors (для базовых описаний), facts (фактические данные).

Типы данных metafields

Тип Примеры использования
single_line_text_field Артикул поставщика, бренд, цвет
multi_line_text_field Расширенные характеристики
rich_text_field Форматированный контент с HTML
number_integer Количество, возраст, год
number_decimal Вес, объём, коэффициент
boolean Признаки: хит, новинка, эксклюзив
date Дата производства, срок годности
date_time Точный timestamp события
url Ссылка на документ, видео-обзор
json Структурированные данные (массив характеристик)
color Цвет в HEX (#RRGGBB)
weight Вес с единицей измерения
volume Объём с единицей
dimension Размер с единицей
rating Рейтинг с диапазоном (min/max)
file_reference Ссылка на файл в медиабиблиотеке
product_reference Ссылка на другой продукт
collection_reference Ссылка на коллекцию
variant_reference Ссылка на вариант
page_reference Ссылка на страницу
mixed_reference Ссылка на любой ресурс

Типы *_reference и file_reference можно объявить списком (list.*) для хранения массива значений.

Создание metafield definitions через Admin

Admin > Settings > Custom data — интерфейс для создания определений метаполей. Определение фиксирует тип данных и делает поле доступным в карточках товаров/коллекций в Admin.

Без definition метаполе можно создать через API, но оно не будет отображаться в Admin UI и не будет доступно через Liquid (только через Storefront API).

Создание через GraphQL Admin API

// Создание metafield definition
const CREATE_DEFINITION = `
  mutation metafieldDefinitionCreate($definition: MetafieldDefinitionInput!) {
    metafieldDefinitionCreate(definition: $definition) {
      createdDefinition {
        id
        name
        namespace
        key
        type { name }
      }
      userErrors { field message }
    }
  }
`;

await client.query({
  data: {
    query: CREATE_DEFINITION,
    variables: {
      definition: {
        name: "Срок доставки (дней)",
        namespace: "custom",
        key: "delivery_days",
        type: "number_integer",
        ownerType: "PRODUCT",
        validations: [
          { name: "min", value: "1" },
          { name: "max", value: "90" }
        ],
        pin: true  // Показывать вверху в карточке товара
      }
    }
  }
});

Массовое заполнение метаполей

Через Admin API для существующих продуктов:

// Установка метаполей для продукта
const SET_METAFIELDS = `
  mutation metafieldsSet($metafields: [MetafieldsSetInput!]!) {
    metafieldsSet(metafields: $metafields) {
      metafields { id key namespace value }
      userErrors { field message }
    }
  }
`;

await client.query({
  data: {
    query: SET_METAFIELDS,
    variables: {
      metafields: [
        {
          ownerId: "gid://shopify/Product/123456789",
          namespace: "custom",
          key: "delivery_days",
          type: "number_integer",
          value: "3"
        },
        {
          ownerId: "gid://shopify/Product/123456789",
          namespace: "specifications",
          key: "warranty_years",
          type: "number_integer",
          value: "2"
        }
      ]
    }
  }
});

При массовом импорте — пакетировать по 25 метаполей на запрос (лимит API).

Вывод метаполей в Liquid-теме

Определённые через Admin metafield definitions доступны в Liquid напрямую:

{%- comment -%} sections/product-specs.liquid {%- endcomment -%}

{%- assign delivery = product.metafields.custom.delivery_days -%}
{%- assign warranty = product.metafields.specifications.warranty_years -%}
{%- assign related = product.metafields.custom.related_products.value -%}

<div class="product-specs">
  {%- if delivery != blank -%}
    <div class="spec-row">
      <span class="spec-label">Срок доставки:</span>
      <span class="spec-value">{{ delivery.value }} {{ delivery.value | pluralize: 'день', 'дня', 'дней' }}</span>
    </div>
  {%- endif -%}

  {%- if warranty != blank -%}
    <div class="spec-row">
      <span class="spec-label">Гарантия:</span>
      <span class="spec-value">{{ warranty.value }} г.</span>
    </div>
  {%- endif -%}
</div>

{%- comment -%} Список связанных продуктов (list.product_reference) {%- endcomment -%}
{%- if related != blank -%}
  <div class="related-products">
    <h3>Также подходит:</h3>
    {%- for related_product in related -%}
      <a href="{{ related_product.url }}">{{ related_product.title }}</a>
    {%- endfor -%}
  </div>
{%- endif -%}

Для метаполей типа rich_text_field — вывод через metafield.value:

{%- assign rich = product.metafields.custom.extended_description -%}
{%- if rich != blank -%}
  <div class="product-extended">
    {{ rich.value }}
  </div>
{%- endif -%}

Метаполя через Storefront API (для headless)

// GraphQL Storefront API
const PRODUCT_WITH_METAFIELDS = `
  query productByHandle($handle: String!) {
    product(handle: $handle) {
      title
      metafield(namespace: "custom", key: "delivery_days") {
        value
        type
      }
      variants(first: 10) {
        edges {
          node {
            metafield(namespace: "specifications", key: "color_hex") {
              value
            }
          }
        }
      }
    }
  }
`;

По умолчанию metafields не возвращаются в Storefront API — нужно явно указать namespace и key либо настроить Storefront API permissions в Admin.

Метаобъекты (Metaobjects)

Более мощная альтернатива — Metaobjects. Это кастомные типы контента (вроде CMS-типов) со своими полями, которые можно ссылочно использовать в метаполях продуктов.

Пример: создать тип Brand с полями name, logo, country, description, затем в продукте использовать метаполе типа metaobject_reference указывающее на экземпляр Brand.

{%- assign brand = product.metafields.custom.brand.value -%}
{%- if brand -%}
  <div class="brand-block">
    <img src="{{ brand.fields.logo.value | image_url: width: 120 }}" alt="{{ brand.fields.name.value }}">
    <span>{{ brand.fields.name.value }}</span>
    <span>{{ brand.fields.country.value }}</span>
  </div>
{%- endif -%}

Сроки

Настройка 10–20 metafield definitions с выводом в теме: 1–2 дня. Массовое заполнение метаполей через скрипт для существующего каталога (1000–10000 товаров): 1–3 дня включая написание скрипта маппинга и прогон. Разработка структуры на Metaobjects для сложного каталога (бренды, материалы, сертификаты): 3–5 дней.