Розробка кастомних компонентів VitePress (Vue)

Наша компанія займається розробкою, підтримкою та обслуговуванням сайтів будь-якої складності. Від простих односторінкових сайтів до масштабних кластерних систем, побудованих на мікро сервісах. Досвід розробників підтверджено сертифікатами від вендорів.

Розробка та обслуговування будь-яких видів сайтів:

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

Це лише деякі з технічних типів сайтів, з якими ми працюємо, і кожен із них може мати свої специфічні особливості та функціональність, а також бути адаптованим під конкретні потреби та цілі клієнта.

Пропоновані послуги
Показано 1 з 1 послугУсі 2065 послуг
Розробка кастомних компонентів VitePress (Vue)
Середня
~2-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

Розробка кастомних компонентів VitePress (Vue)

VitePress дозволяє використовувати Vue 3 SFC-компоненти напрямку в Markdown через глобальну реєстрацію або імпорт. Це головна перевага перед Docusaurus для Vue-орієнтованих проектів.

Реєстрація та використання

// .vitepress/theme/index.ts
import { defineAsyncComponent } from 'vue';
import DefaultTheme from 'vitepress/theme';

export default {
  extends: DefaultTheme,
  enhanceApp({ app }) {
    // Синхронна реєстрація
    app.component('CodePlayground', CodePlayground);

    // Асинхронна (ленива загрузка)
    app.component('HeavyChart', defineAsyncComponent(() =>
      import('./components/HeavyChart.vue')
    ));
  },
};
# How it works

<CodePlayground
  :code="`const x = 1 + 1;\nconsole.log(x);`"
  language="javascript"
/>

Інтерактивний Code Playground

<!-- .vitepress/theme/components/CodePlayground.vue -->
<script setup lang="ts">
import { ref, computed, onMounted } from 'vue';
import { shikiToHighlighter } from '@shikijs/vitepress-twoslash';

const props = defineProps<{
  code: string;
  language: string;
  editable?: boolean;
}>();

const userCode = ref(props.code);
const output = ref('');
const isRunning = ref(false);

const highlighted = computed(() => {
  // Використовуємо Shiki для підсвічення
  return highlighter.codeToHtml(userCode.value, { lang: props.language });
});

const runCode = async () => {
  isRunning.value = true;
  const logs: string[] = [];
  const sandbox = new Function('console', userCode.value);
  try {
    sandbox({ log: (...args) => logs.push(args.join(' ')) });
    output.value = logs.join('\n');
  } catch (e: any) {
    output.value = `Error: ${e.message}`;
  }
  isRunning.value = false;
};
</script>

<template>
  <div class="code-playground">
    <div class="code-playground__editor">
      <textarea
        v-if="editable"
        v-model="userCode"
        class="code-playground__textarea"
        spellcheck="false"
      />
      <div v-else v-html="highlighted" />
    </div>
    <div class="code-playground__footer">
      <button @click="runCode" :disabled="isRunning">
        {{ isRunning ? 'Running...' : '▶ Run' }}
      </button>
      <pre v-if="output" class="code-playground__output">{{ output }}</pre>
    </div>
  </div>
</template>

Компонент для демонстрації UI

<!-- Демонстрація React/Vue компонентів прямо в документації -->
<script setup lang="ts">
import { ref } from 'vue';

const variant = ref('primary');
const disabled = ref(false);
</script>

<template>
  <div class="component-demo">
    <div class="demo-preview">
      <button :class="`btn btn--${variant}`" :disabled="disabled">
        Sample Button
      </button>
    </div>

    <div class="demo-controls">
      <label>
        Variant:
        <select v-model="variant">
          <option value="primary">Primary</option>
          <option value="secondary">Secondary</option>
          <option value="danger">Danger</option>
        </select>
      </label>
      <label>
        <input type="checkbox" v-model="disabled"> Disabled
      </label>
    </div>
  </div>
</template>

Компонент з даними з API

<script setup lang="ts">
import { ref, onMounted } from 'vue';
// VitePress підтримує лише browser-сумісний код у компонентах
// Дані мають передаватися через props з Markdown frontmatter
// або завантажуватися на клієнті

const props = defineProps<{ endpoint: string }>();
const data = ref(null);

onMounted(async () => {
  // Запити лише в browser (не під час SSG)
  if (typeof window !== 'undefined') {
    data.value = await fetch(props.endpoint).then(r => r.json());
  }
});
</script>

Глобальні дані через useData

<script setup>
import { useData, useRoute } from 'vitepress';
const { site, page, theme, frontmatter, lang, isDark } = useData();
const route = useRoute();
</script>

<template>
  <div>{{ frontmatter.title }} | {{ site.title }}</div>
  <div>Current path: {{ route.path }}</div>
</template>

Розробка 3–5 кастомних Vue-компонентів для документації — 2–4 дні.