Имя тега равно null или не является объектом - сообщение об ошибке в IE 7 с использованием последней версии jQuery (1.2.6)

Кто-нибудь еще видел это сообщение об ошибке. быстрая проверка с помощью гугла мне мало что показывает.

Дайте нам образец кода, который вызывает эту проблему - держу пари, что jessegavin на что-то наткнулся ...

Jason Bunting 17.09.2008 20:28
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
1
1
5 834
4
Перейти к ответу Данный вопрос помечен как решенный

Ответы 4

Вы, наверное, пытаетесь сделать что-то подобное ....

alert($("#myElement").tagName);

Ты должен сделать это ...

alert($("#myElement")[0].tagName);

alert ($ ("# myElement"). get (0) .tagName), возможно, будет предпочтительным синтаксисом для вашего примера.

Kent Fredric 17.09.2008 20:35

документы jQuery говорит: «Эта функция, вызываемая как $ (this) .get (0), эквивалентна использованию квадратных скобок в самом объекте jQuery, например, $ (this) [0]».

jessegavin 18.09.2008 18:48

Убедитесь, что вы запускаете свой скрипт ПОСЛЕ отображения страницы. Если ваш сценарий находится вверху страницы и запускается сразу же, а ваш DIV находится под этим сценарием, DIV еще не существует.

Ответ принят как подходящий

извините, это был вопрос с моей стороны. Сейчас я просматриваю свои файлы .js и удаляю целые блоки кода. Я изолировал его от одного конкретного файла .js.

все равно спасибо за то, что прочитали этот вопрос и ответили.

Если вы видите это только в IE, это может быть ошибка веб-плагина DivX:

http://drupal.org/node/1038058

Проблема подтверждена на сайте DivX с надписью «Исправлено в следующем выпуске» (апрель 2011 г.).

http://labs.divx.com/node/16824

По сути, ошибка заключается в том, что DivX заменяет функцию el.appendChild () перехватчиком, который пытается перевести тэг в нижний регистр, но не проверяет, является ли это текстовым узлом. Это сломает jQuery, если вы попытаетесь сделать что-то вроде $('body').append('hi!'). Кроме того, он не может вернуть элемент, что, например, нарушает SWFObject.

Обходной путь - убедиться, что вы никогда не вызываете append () с текстовым узлом или с несколькими элементами верхнего уровня. Если вы добавляете ряд элементов:

  append($('<div>hi</div><div>there</div>')) 

убедитесь, что вы заключили их в div верхнего уровня, чтобы избежать подразумеваемого текстового узла:

  append($('<div><div>hi</div><div>there</div></div>')) 

Вот полный обходной путь для выхода из строя appendChild, тот же подход можно использовать для insertBefore и replaceChild, которые разделяют ошибку. Divx JS вставляется через некоторое время после загрузки страницы, поэтому вы можете опросить об этом.

window.fixDivxPlayerBug = function () {
    var b = document.getElementsByTagName('body')[0];
    if ( window['ReplaceVideoElements'] && ! b.appendChildDivx ){
        b.appendChildDivx = b.appendChild;
        b.appendChild = function (el) {
            if ( el.tagName == null) {
                var wrap = document.createElement('div');
                wrap.appendChild(el);
                b.appendChildDivx(wrap);
            }
            else {
                b.appendChildDivx(el);
            }
            return el;
        };
    }
};

Другие вопросы по теме