1С Битрикс Управления сайтом довольно мощная и гибкая CMS позволяющая решать множество задач веб-разработки. В ней так же предусмотрены механизмы расширения базовых возможностей системы по средством собвтенных компонентов, модулей и классов. Давайте рассмотрим последние и разберёмся как же загружать их в систему.

1С Битрикс Управления сайтом довольно мощная и гибкая CMS позволяющая решать множество задач веб-разработки. В ней так же предусмотрены механизмы расширения базовых возможностей системы по средством собвтенных компонентов, модулей и классов. Давайте рассмотрим последние и разберёмся как же загружать их в систему.

Существует 2 основных варианта подключения своего класса (сейчас я не рассматриваю модули и компоненты, в них так же можно создавать классы и подключаь методами CModule::IncludeModue(‘module_name’) или же через компоненты $APPLICATION->IncludeComponent()):

  1. Через автозагрузчик классов битрикс
  2. По средствам composer

Автозагрузка классов 1С Битрикс

Первым делом необходимо расположить класс в удобном для этого месте, где его не затрут обновления системы и с ним будет удобно работать. Обычно я размещаю классы в папке /local/php_interface/lib/#папка_с_типом_класса#/ — здесь #папка_с_типом_класса# это директория собирающая однотипные классы в одном месте, например для работы с собственными пользовательскими свойствами или информационными блоками, для простоты пока опустим эту папку и поместим прямо в корень /lib/. Назовём его someclass.php:


<?php

namespace lib;


class SomeClass
{
    public static function someMethod()
    {

    }
}

Теперь в папке /local/php_interface/ создадим файл autoload.php где вызовем метод Bitrix\Main\Loader::registerAutoLoadClasses() вот с такими настройками:

<?

Bitrix\Main\Loader::registerAutoLoadClasses(null, [
    'lib\SomeClass' => '/local/php_interface/lib/SomeClass.php'
]);

Сам файл естественно необходимо подключить в /local/php_interface/init.php в самом начале:

<?

require_once( $_SERVER['DOCUMENT_ROOT'] . '/local/php_interface/autoload.php');

Таким образом, как только нам потребуется воспользоваться нашим классом, 1С Битрикс, автоматически его подгрузит.

Загрузка классов через Composer

Так же для автозагрузки классов битрикс можно использовать популярный менеджер зависимостей composer. Он сам создаст файл autoload.php который будет отвечать за автозагрузку наших классов. Чтобы использовать composer вам необходимо в папке  /local/php_interface/ создать файл composer.json со следующим содержимым:


{
  "autoload": {
    "psr-4": {
      "lib\\": "lib/"
    }
  }
}

здесь первый «lib\\» (ключ) — это пространство имён наших классов, а «lib/» это папка (относительно директории где создан conposer.json) где будут лежать наши классы.  Затем открываем консоль, переходим в папку /local/php_interface/ и запускаем команду composer install. Если всё сделано правильно и у вас или на сервере установлен composer вы увидите следующее сообщение:

Loading composer repositories with package information
Updating dependencies (including require-dev)
Nothing to install or update
Generating autoload files

При этом composer создаст новую папку /vendor/ и файл autoload.php, который нам осталось загрузить в init.php как мы делали в первом методе:

<? 
require_once ( $_SERVER['DOCUMENT_ROOT'] . '/local/php_interface/vendor/autoload.php' );


Лично мне, второй вариант нравится больше, т.к. я часто использую в своих проектах сторонние библиотеки, которые как раз устанавливаю при помощи composer и т.к. у меня всё равно подключен /vendor/autoload.php, не вижу смысла подключать собственные классы через автозагрузчик битрикса. Но это дело вкуса.

Используйте современные инструменты и пусть ваш код работает быстро и правильно!⁠

Вам также могут понравиться

Современные способы заработка на сайтах

Современные способы заработка на сайтах

Не для кого не секрет, что в современном мире вы можете зарабатывать определённые деньги на своём сайте ничего не продавая. Говоря «ничего не продавая», я имею ввиду классическую схему, когда вы продаёте свои услуги, перепродаёте товар (предварительно закупая или используя схемы прямой поставки «дроп-шиппинга») или что-то производите. В статье рассмотрим методы, которые не требуют от вас подобных действий. И так, рассмотрим основные методы в порядке возрастания их сложности и времени которое требуется от владельца сайта.

Пользовательский тип свойств инфоблока в 1С Битрикс

Пользовательский тип свойств инфоблока в 1С Битрикс

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

Условные операторы в PHP

Условные операторы в PHP

Добрались до логики выполнения программы. И так условные операторы (по другому операторы ветвления) позволяют нам организовать определённое поведение программы в зависимости от входных параметров (данных вводимых пользователем, результатом работы вспомогательных функций). Вся логика в языках программирования основана на Алгебре Буля. 

Комментарии
Защита от автоматических сообщений
CAPTCHA
Введите слово на картинке
04.10.2020 | Дмитрий

Спасибо за статью. Помогла. Не знал, что после добавления классов в psr-4 нужно делать в composer install.

Комментировать | 0  
Защита от автоматических сообщений
CAPTCHA
Введите слово на картинке
Закрыть

Самые читаемые

Тонкая настройка SEO для результатов фильтрации каталога битрикс

Тонкая настройка SEO для результатов фильтрации каталога битрикс

Одним из преимуществ интернет-магазинов на 1С Битрикс на мой взгляд является наличие не так давно до...

Основы SEO оптимизации сайта

Основы SEO оптимизации сайта

Эта статья не истина в последней инстанции, а лишь набор правил которые я применяю при создании/испр...

Собственный тип пользовательских полей в 1С Битрикс

Собственный тип пользовательских полей в 1С Битрикс

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