Web Мастерская»Блог

Сообщество Web Мастеров. Тут собрано всё, чтобы написать свой первый сайт, запустить его в Интернет и поддерживать его в течении всей его работы.

SVG: Атрибут transform

SVG
Scalable Vector Graphics (SVG) — это мощный инструмент для создания векторной графики, которая способна масштабироваться без потери качества. Одним из ключевых аспектов работы с SVG является возможность трансформировать элементы, что позволяет создавать динамичные и интерактивные изображения. В этой статье мы рассмотрим атрибут transform и его возможности.

Что такое атрибут transform?


Атрибут transform позволяет изменять положение, ориентацию и размер элементов SVG. Он поддерживает шесть основных типов трансформаций:
  • translate: перемещение элемента по осям X и Y.
  • scale: масштабирование элемента по осям X и Y.
  • rotate: поворот элемента вокруг центральной точки.
  • skewX: наклон элемента по оси X.
  • skewY: наклон элемента по оси Y.
  • matrix: произвольная матричная трансформация.

Примеры использования атрибута transform



Translate
Трансформация translate позволяет переместить элемент на указанное количество единиц по осям X и Y:
<rect x="10" y="10" width="100" height="100"
...

PHP: Cannot redeclare class

Если вы получили ошибку «Fatal error: Cannot redeclare class», значит, ваш скрипт пытается повторно объявить класс, который уже был объявлен ранее. Давайте разберемся, почему это происходит и как это исправить.

Что означает ошибка «Cannot redeclare class»?


Эта ошибка возникает, когда PHP встречает попытку повторного объявления класса, который уже был объявлен ранее. Такое часто бывает при неправильном включении файлов или использовании автозагрузки классов.

Пример ошибки:
class MyClass {}

// ...

class MyClass {} // Повторное объявление

При выполнении этого кода PHP выдаст ошибку:
Fatal error: Cannot redeclare class MyClass

Причины появления ошибки


  1. Повторное включение файлов: если вы используете конструкции include или require, убедитесь, что файл с классом подключается только один раз.
  2. Автозагрузка классов: если используете автозагрузку классов (например, через Composer), убедитесь, что класс не загружается повторно.
  3. Пространства имен: если используете пространства имен,
...

PHP: Как перевести zXXX в часовой пояс?

PHP
В PHP аббревиатуру типа «Z260» напрямую перевести в часовой пояс невозможно, так как это обозначение нестандартное и не общепринятое в PHP. Обычно часовые пояса представлены в формате Continent/City (например, Europe/Moscow, America/Los_Angeles) или с использованием сдвигов от Всемирного координированного времени (UTC), например, UTC+3.

Что делать, если нужно получить часовой пояс из нестандартного обозначения типа «zXXX»?



Связать «zXXX» с конкретным городом или регионом
Если известно, что «zXXX» соответствует определённому городу или региону, можно создать таблицу соответствия и переводить вручную:
$zoneMapping = [
    'zXXX' => 'Europe/Moscow', // например, Москва
    // другие пары Zone -> City
];

$tz = $zoneMapping['Z260'];
$dt = new DateTime('now', new DateTimeZone($tz));
echo $dt->format('Y-m-d H:i:s e');

Если «zXXX» содержит смещение (например, UTC±3)
Если «zXXX» обозначает смещение относительно UTC, можно воспользоваться этим смещением:
$offsetHours =
...

Fatal error: Allowed memory size exhausted

Одна из самых неприятных ошибок, с которыми сталкиваются разработчики на PHP, звучит так: Fatal error: Allowed memory size of XXX bytes exhausted (tried to allocate YYY bytes).

Эта ошибка возникает, когда ваш PHP-скрипт исчерпал отведённую ему память. Чаще всего она проявляется при выполнении ресурсоемких операций, таких как обработка больших файлов, массивов или сложных расчетов.

Причины возникновения ошибки


Есть несколько причин, почему может возникнуть эта ошибка:
  • Обработка больших данных: попытка загрузить в память гигантский файл или огромный массив данных.
  • Бесконечные циклы: неисправный цикл, который накапливает данные бесконечно, расходуя память.
  • Неконтролируемое увеличение объектов: динамическое создание множества объектов без освобождения памяти.
  • Повышенные требования к памяти: некоторые библиотеки или расширения могут требовать значительных объемов памяти для работы.

Как обнаружить проблему


Первым делом нужно локализовать место, где возникает ошибка. Вот несколько способов:
  1. Отладк
...

Как проверить видимый или невидимый элемент

Проверить, виден ли элемент на странице, можно несколькими способами. Видимость элемента определяется не только наличием свойства display: none, но и другими факторами, такими как высота и ширина равные нулю, видимость родителей и многое другое.

Варианты проверки видимости элемента:

Проверка с помощью jQuery


В jQuery есть специальный метод .is(':visible'), который проверяет видимость элемента:
if ($('#myElement').is(':visible')) {
    console.log('Элемент виден');
} else {
    console.log('Элемент скрыт');
}

Проверка с помощью чистого JavaScript


Можно воспользоваться чистым JavaScript, проверив несколько свойств элемента:
function isVisible(element) {
    const style = window.getComputedStyle(element);
    return !(style.display === 'none' ||
             style.visibility === 'hidden' ||
             parseFloat(style.opacity) <= 0 ||
             element.offsetWidth === 0 ||
             element.offsetHeight === 0);
}

const el =
...