Разработка личного кабинета на Vue.js для 1С-Битрикс

Наша компания занимается разработкой, поддержкой и обслуживанием решений на Битрикс и Битрикс24 любой сложности. От простых одностраничных сайтов до сложных интернет магазинов, CRM систем с интеграцией 1С и телефонии. Опыт разработчиков подтвержден сертификатами от вендора.
Предлагаемые услуги
Показано 1 из 1 услугВсе 1626 услуг
Разработка личного кабинета на Vue.js для 1С-Битрикс
Средняя
~1-2 недели
Часто задаваемые вопросы
Наши компетенции:
Этапы разработки
Последние работы
  • image_website-b2b-advance_0.png
    Разработка сайта компании B2B ADVANCE
    1258
  • image_bitrix-bitrix-24-1c_fixper_448_0.png
    Разработка веб-сайта для компании ФИКСПЕР
    849
  • image_bitrix-bitrix-24-1c_development_of_an_online_appointment_booking_widget_for_a_medical_center_594_0.webp
    Разработка на базе Битрикс, Битрикс24, 1С для компании Development of an Online Appointment Booking Widget for a Medical Center
    584
  • image_bitrix-bitrix-24-1c_mirsanbel_458_0.webp
    Разработка на базе 1С Предприятие для компании МИРСАНБЕЛ
    751
  • image_crm_dolbimby_434_0.webp
    Разработка сайта на CRM Битрикс24 для компании DOLBIMBY
    657
  • image_crm_technotorgcomplex_453_0.webp
    Разработка на базе Битрикс24 для компании ТЕХНОТОРГКОМПЛЕКС
    989

Разработка личного кабинета на Vue.js для 1С-Битрикс

Личный кабинет — раздел, где SEO не важен, зато важны скорость и удобство. Это идеальный кандидат для перевода на Vue SPA: навигация без перезагрузок, мгновенная обратная связь на действия, возможность push-уведомлений.

Структура личного кабинета

Типовые разделы ЛК в интернет-магазине на Битрикс:

  • История заказов — список из b_sale_order + детализация по b_sale_order_props, b_sale_basket
  • Профиль — данные из b_user, доп. поля из b_uts_user или свойств пользователя
  • Адресная книга — местоположения из b_sale_location, кастомные адреса
  • Избранное — кастомная таблица или b_iblock_element_property с типом «пользователь»
  • Бонусная программа — данные из модуля loyalty или кастомных таблиц

Инициализация: передача данных пользователя

Битрикс сервер передаёт данные авторизованного пользователя при загрузке страницы ЛК:

// В шаблоне раздела /personal/
if (!$USER->IsAuthorized()) {
    LocalRedirect('/auth/?backurl=/personal/');
}

$currentUser = [
    'id' => $USER->GetID(),
    'name' => $USER->GetFullName(),
    'email' => $USER->GetEmail(),
    'groups' => $USER->GetUserGroupArray(),
];

echo '<div id="lk-app" data-user="' . htmlspecialchars(json_encode($currentUser)) . '"></div>';

Vue читает из dataset.user, инициализирует auth store без дополнительного запроса.

API для разделов ЛК

Каждый раздел — отдельный контроллер:

// Контроллер заказов
class OrderController extends \Bitrix\Main\Engine\Controller
{
    public function listAction(int $page = 1): array
    {
        $userId = $this->getCurrentUser()->getId();
        // Выборка из b_sale_order WHERE USER_ID = $userId
        // LIMIT 10 OFFSET ($page-1)*10
    }

    public function detailAction(int $orderId): array
    {
        // Проверка принадлежности заказа текущему пользователю — обязательно
        $order = \Bitrix\Sale\Order::load($orderId);
        if ($order->getUserId() !== $this->getCurrentUser()->getId()) {
            throw new \Bitrix\Main\AccessDeniedException();
        }
    }
}

Проверка принадлежности — критически важна, IDOR-уязвимость без неё.

Навигация через Vue Router

const routes = [
    { path: '/personal/', component: Dashboard },
    { path: '/personal/orders/', component: OrderList },
    { path: '/personal/orders/:id/', component: OrderDetail },
    { path: '/personal/profile/', component: ProfileEdit },
    { path: '/personal/wishlist/', component: Wishlist },
];

Битрикс настраивается на отдачу одного шаблона для всех URL /personal/*.

Случай из практики

Дистрибьютор промышленного оборудования: ЛК с 6 разделами, включая управление дочерними аккаунтами (менеджер видит заказы своих клиентов) и документооборотом (скачивание счетов, актов в PDF). Стандартный Битрикс-ЛК на серверных компонентах: каждый переход — новая загрузка страницы с 1.5–3 сек. Vue SPA: переходы между разделами мгновенные, данные кэшируются в Pinia на 5 минут, PDF-генерация через background job с уведомлением через polling.

Сроки выполнения

Масштаб Срок
Базовый ЛК (заказы, профиль, адреса) от 8 до 12 рабочих дней
С бонусной программой и избранным от 12 до 18 рабочих дней
B2B ЛК с дочерними аккаунтами и документооборотом от 25 до 40 рабочих дней