Частичная кастомизация файлов
Общие принципы работы частичной кастомизации приведены в разделе Кастомизация. Мы рассмотрим пример, взяв за основу файл includes/core.php.
При добавлении изображений в новостях, статьях и т.д. имена файлов формируются на основе имени элемента, в котором происходит сохранение. При этом они автоматически преобразуются в латинские символы с помощью метода translit()
. Пробел по умолчанию заменяется на дефис. Предположим, что перед нами встала необходимость менять пробел на символ нижнего подчеркивания и приводить все символы к строчному виду.
Создадим новый файл includes/core.custom.php и добавим в него новые методы.
Пример:
abstract class Core
{
replace public function translit ($text)
{
$ru = array('а', 'б', 'в', 'г', 'д', 'е', 'ё', 'ж', 'з', 'и', 'й', 'к', 'л', 'м', 'н', 'о', 'п', 'р', 'с', 'т', 'у', 'ф', 'х', 'ц', 'ч', 'ш', 'щ', 'ы', 'э', 'ю', 'я', 'А', 'Б', 'В', 'Г', 'Д', 'Е', 'Ё', 'Ж', 'З', 'И', 'Й', 'К', 'Л', 'М', 'Н', 'О', 'П', 'Р', 'С', 'Т', 'У', 'Ф', 'Х', 'Ц', 'Ч', 'Ш', 'Щ', 'Ы', 'Э', 'Ю', 'Я', ' ');
$tr = array('a', 'b', 'v', 'g', 'd', 'e', 'yo', 'zh', 'z', 'i', 'y', 'k', 'l', 'm', 'n', 'o', 'p', 'r', 's', 't', 'u', 'f', 'kh', 'ts', 'ch', 'sh', 'sch', 'y', 'e', 'yu', 'ya', 'A', 'B', 'V', 'G', 'D', 'E', 'YO', 'ZH', 'Z', 'I', 'Y', 'K', 'L', 'M', 'N', 'O', 'P', 'R', 'S', 'T', 'U', 'F', 'KH', 'TS', 'CH', 'SH', 'SCH', 'Y', 'E', 'YU', 'YA', '_');
$text = str_replace($ru, $tr, $text);
$text = $this->prepare_translit($text);
return $text;
}
new private function prepare_translit ($text)
{
$text = strtolower($text);
return $text;
}
}
Здесь следует обратить внимание на слово replace перед модификатором доступа public метода translit()
. Оно говорит системе, что данный метод уже существует в исходном файле,
но использовать его не нужно. Т. е. всякий раз при обращении к оригинальному translit()
будет срабатывать translit()
из файла includes/core.custom.php.
Приставка new позволяет добавить новый метод в существующий класс, что мы и сделали на примере prepare_translit()
.
Помимо новых методов можно создавать и новые свойства класса. Сделаем это с переменными $ru
и $tr
.
Пример:
abstract class
Core
{
new private $ru = array('а', 'б', 'в', 'г', 'д', 'е', 'ё', 'ж', 'з', 'и', 'й', 'к', 'л', 'м', 'н', 'о', 'п', 'р', 'с', 'т', 'у', 'ф', 'х', 'ц', 'ч', 'ш', 'щ', 'ы', 'э', 'ю', 'я', 'А', 'Б', 'В', 'Г', 'Д', 'Е', 'Ё', 'Ж', 'З', 'И', 'Й', 'К', 'Л', 'М', 'Н', 'О', 'П', 'Р', 'С', 'Т', 'У', 'Ф', 'Х', 'Ц', 'Ч', 'Ш', 'Щ', 'Ы', 'Э', 'Ю', 'Я', ' ');
new private $tr = array('a', 'b', 'v', 'g', 'd', 'e', 'yo', 'zh', 'z', 'i', 'y', 'k', 'l', 'm', 'n', 'o', 'p', 'r', 's', 't', 'u', 'f', 'kh', 'ts', 'ch', 'sh', 'sch', 'y', 'e', 'yu', 'ya', 'A', 'B', 'V', 'G', 'D', 'E', 'YO', 'ZH', 'Z', 'I', 'Y', 'K', 'L', 'M', 'N', 'O', 'P', 'R', 'S', 'T', 'U', 'F', 'KH', 'TS', 'CH', 'SH', 'SCH', 'Y', 'E', 'YU', 'YA', '_');
replace public function translit ($text)
{
$text = str_replace($this->ru, $this->tr, $text);
return $text;
}
}
Помимо new и replace существуют также before и after, позволяющие расширить метод и добавить необходимый код в его начало или конец, соответственно. Используются они аналогично примерам, приведенным выше.
Зарегистрируйтесь или авторизируйтесь для того, чтобы оставить комментарий.
Ваш комментарий будет первым.