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

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

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 = document.querySelector('#myElement');
if
...

jQuery: Как в проверить существует ли элемент

Проверить, существует ли определенный элемент на странице с помощью jQuery, можно несколькими способами. Наиболее популярны два подхода:

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


Самый распространенный метод — проверить длину выбранного элемента с помощью свойства .length. Если длина больше 0, значит элемент существует.
if ($('#myBlock').length > 0) {
    alert('Блок существует!');
} else {
    alert('Блок не найден!');
}

Пример:Допустим, у нас есть блок с id myBlock. Если он присутствует на странице, то сообщение будет "Блок существует!". Иначе — "Блок не найден!".

Проверка с помощью оператора is()


Другой способ — использовать метод is(), который возвращает true, если выбранный элемент существует, и false в противном случае.
if ($('#myBlock').is('*')) {
    alert('Блок существует!');
} else {
    alert('Блок не найден!');
}

Примечание: Метод is('*') проверяет, есть ли хотя бы один элемент в DOM, соответствующий данному селектору.

Прямая проверка наличия элементов


Иногда бывает полезно...

Cannot read properties of undefined (reading 'top')

Такая ошибка обычно появляется, когда программа пытается обратиться к свойствам объекта, который оказался неопределённым (undefined). Чаще всего это случается при ошибочной передаче аргументов, неправильной инициализации переменных или попытке считать данные из пустого объекта.

Причина ошибки


В конкретном сообщении говорится, что нельзя прочитать свойство top у неопределённого объекта. Значит, программа обращается к какому-то объекту, ожидая, что у него есть свойство top, но этот объект оказался неопределённым.

Как исправить ошибку?



1. Проверь существование объекта
Перед чтением свойства top убедись, что объект определен:
let obj = {};

if (obj && typeof obj.top !== 'undefined') {
    console.log(obj.top);
} else {
    console.error('Объект не содержит свойство top');
}

2. Убедись, что объект правильно передан
Проверь, верно ли присваиваются значения объектам, функциям или параметрам. Например, если объект приходит от какого-то метода или API, удостоверься, что данные получены...

Failed to execute 'appendChild' on 'Node': Unexpected identifier 'array'

Ошибка: Failed to execute 'appendChild' on 'Node': Unexpected identifier 'array' звучит, как результат некорректного использования JavaScript.

Эта ошибка говорит о том, что при вызове метода appendChild() была предоставлена неверная или неподходящая переменная. Метод appendChild() ожидает, что ему будет передан узел DOM (например, элемент HTML), а не что-то другое (например, массив или строка).

Возможные причины ошибки:
  1. Передача неправильного типа данных: Возможно, вы передали массив или строку вместо узла DOM.
  2. Неверное наименование переменной: Возможно, переменная названа неправильно или содержит ошибку в наименовании.
  3. Неправильное создание элемента: Возможно, элемент не был создан корректно перед попыткой его добавления.

Пример возможной ошибки:
let elements = []; // Здесь подразумевается массив элементов

for (let i = 0; i < elements.length; i++) {
    container.appendChild(elements[i]); // Ошибка возникнет, если elements[i] не является узлом DOM
}

Как исправить ошибку


  1. Проверьте тип
...