Архитектура OpenCart

До этого момента, наши статьи OpenCart охватывали пользовательский интерфейс. В этой же части, мы рассмотрим, как пользоваться панелью администрирования. Начиная с этого момента, будем более детально знакомиться с OpenCart Framework, который построен по принципу MVC.

Если вы знакомы с MVC (Модель-Представлени-Контроллер), то вам будет гораздо проще; в противном случае, не беспокойтесь, мы подробно обсудим архитектуру MVC в следующих статьях.

Содержание

Разбор параметров URL маршрутизации

OpenCart Framework проектировался так, чтобы даже разработчики среднего уровня могли с лёгкостью включиться в работу. В OpenCart используется простой механизм URL маршрутизации. К примеру: route=aa/bb. Слово «route» состоит из двух частей, которые сообщают фрэймворку, какую страницу нужно загрузить.

В приведённом примере aa — это первая часть, bb — вторая. В рамках архитектуры MVC, будет подключён следующий файл: в первую очередь загружается контроллер. В нашем случае, его название передаётся в пером и втором параметре строки запроса. Первая часть строки запроса указывает на каталог, вторая на название контроллера.

Итак, в результате нашего запроса, будет открыт следующий файл:

(STORE ROOT DIRECTORY)/catalog/controller/aa/bb.php

Заметка: так же через маршрутизатор можно передать и третий параметр, route=aa/bb/cc. Его мы подробно обсудим в следующий статьях, где сфокусируемся на работе контроллеров.

Библиотеки

В OpenCart огромную роль играют библиотеки. В общем, библиотеки представляют собой вспомогательные файлы, которые частенько используются во время разработки. В OpenCart есть определённые библиотеки, которые могут быть очень полезны во время написания кода. Синтаксис загрузки библиотеки: $this->library_name. Все библиотеки можно найти в system/library.

К примеру, для аутентификации пользователя, вы можете написать $this->user->login($username,$password); Для выхода из системы: $this->user->logout();.

Самые часто используемые библиотеки:

  • cart.php: работа с корзиной
  • image.php функции для работы с изображениями. Обрезка, кэширование и многое другое
  • customer.php функции для работы с покупателями
  • config.php работа с настройками OpenCart
  • user.php содержит функции для работы с пользователями.

Языки

Все доступные языки можно найти в каталоге catalog/language. В предыдущих статьях мы добавили французский язык, так что на данный момент у нас есть две папки: english и french. Для большего понимания, давайте рассмотрим содержимое каталога english.

Все значение переводимых строк можно найти в файле english.php. Если вы захотите добавить какое-то значение, то следуйте следующему синтаксису:

$_['language_key']='This is test';

В то же время, значения для специфических страниц можно найти внутри других папок. К примеру, переводы для страницы ошибки можно найти в: catalog/language/english/error/not_found.php.

Файл языка подгружается следующим образом:

$this->language->load('error/not_found');

Теперь, используя метод «get», можете извлечь любое значение:

$this->language->get('language_key');

Заметка: все значения из глобального файла english/english.php загружаются автоматически. Поэтому для их использования можно избежать вызова $this->language->load.

Вывод

В этой статье мы затронули основы архитектуры OpenCart. Однако это ещё не всё! В следующих двух статьях мы более подробно остановимся на нескольких моментах, касающихся данной темы.

Для того чтобы стать экспертом по работе с каким-то инструментом, вам нужно досконально изучить принцип его работы. В следующих статьях мы займёмся изучением основополагающих вещей. Надеюсь, вам нравятся эти статьи. Ждём ваши комментарии и вопросы.

Данный урок подготовлен для вас командой сайта ruseller.com
Источник урока: http://code.tutsplus.com/articles/from-beginner-to-advanced-in-opencart-the-architecture—cms-21482

Другие статьи близкие по теме

Подписка на новые статьи по почте

Подписка на новые статьи сайта
(Статью прочитали: 81 раз)

Похожие посты

Поделись ссылкой с кем хочешь

Добавить комментарий

Ваш e-mail не будет опубликован. Обязательные поля помечены *