Quais são os motivos típicos de falha do Javascript desenvolvido no Firefox no IE? [fechadas]

108

Desenvolvi algumas páginas aprimoradas com javascript que funcionam bem no Firefox e Safari recentes. Perdi o check-in do Internet Explorer e agora descobri que as páginas não funcionam no IE 6 e 7 (até agora). Os scripts não são executados de alguma forma, as páginas aparecem como se o javascript não estivesse lá, embora algum javascript seja executado. Estou usando bibliotecas próprias com manipulação de dom, da YUI 2 uso o YUI-Loader e o XML-Http-Request e em uma página uso "psupload", que depende do JQuery.

Estou instalando o Microsoft Script Editor a partir do Office XP e agora vou depurar. Também vou escrever testes específicos agora.

Quais são os pontos de falha típicos do IE? Em que direção posso manter meus olhos abertos.

Encontrei esta página, que mostra algumas diferenças. visita: Quirksmode

Você pode, por experiência própria, citar algumas coisas típicas que devo procurar primeiro?

Também farei mais perguntas aqui para tarefas específicas mais tarde, mas por enquanto estou interessado em sua experiência por que o IE geralmente falha em scripts que funcionam bem no Firefox

Edit: Obrigado por todas essas ótimas respostas!

Nesse ínterim, adaptei todo o código para que funcione também com o Internet Explorer. Eu integrei o jQuery e construí minhas próprias classes em cima dele agora. Este foi meu erro básico, que eu não construí todas as minhas coisas no jQuery desde o início. Agora eu tenho.

O JSLint também me ajudou muito.

E muitas das questões individuais das diferentes respostas ajudaram.

user89021
fonte
Não há problemas com css ou estilo até agora, como eu sabia disso na codificação anterior. Apenas problemas de JS - karlthorwald
user89021
1
Vou rodar o JSLint pela primeira vez em todos os arquivos, alguns que nunca adaptei.
user89021
7
"Este foi meu erro básico, não ter construído todas as minhas coisas no jQuery desde o início." - não vai resolver magicamente todos os seus problemas cross-browser. Procure stackoverflow por jQuery e IE, você encontrará toneladas de problemas. Melhor aprender cross-browser scripting sozinho, de forma que quando o jQuery ou um de seus bilhões de plug-ins incompletos falhar, você será capaz de implementar uma solução cross-browser de trabalho real e saber que ela funciona e por quê.
Dagg Nabbit
11
+1 no comentário de não acima. É MUITO melhor evitar jQuery completamente IFF você está aprendendo javascript - jQuery é incrivelmente útil se você quiser fazer algo complexo de forma rápida e fácil, mas se você estiver aprendendo, isso o protegerá das complexidades de entender como o javascript na verdade funciona - muitas pessoas parecem saber jQuery, mas não têm a menor idéia de como escrever javascript. Você não cometeu um erro ao não construir originalmente em jQuery - agora você tem uma compreensão muito melhor de seu próprio código do que se tivesse.
lucideer

Respostas:

121

Sinta-se à vontade para atualizar esta lista se encontrar algum erro / omissão, etc.

Observação: o IE9 corrige muitos dos problemas a seguir, portanto, muito disso se aplica apenas ao IE8 e versões anteriores e, até certo ponto, ao IE9 no modo peculiar. Por exemplo, IE9 suporta SVG, <canvas>, <audio>e <video>de forma nativa, no entanto você deve habilitar o modo de cumprimento de normas para que eles estejam disponíveis.


Geral:

  • Problemas com documentos parcialmente carregados: É uma boa ideia adicionar seu JavaScript em um window.onloadevento ou semelhante, pois o IE não oferece suporte a muitas operações em documentos parcialmente carregados.

  • Atributos diferentes : em CSS, é elm.style.styleFloatno IE e elm.style.cssFloatno Firefox. Em <label>tags, o foratributo é acessado com elm.htmlForno IE e elm.forno Firefox. Observe que foré reservado no IE, portanto, elm['for']é provavelmente uma ideia melhor impedir o IE de lançar uma exceção.


Linguagem JavaScript base:

  • Acessar caracteres em strings : 'string'[0]não é compatível com o IE, pois não está nas especificações originais do JavaScript. Use 'string'.charAt(0)ou 'string'.split('')[0]observe que acessar itens em arrays é significativamente mais rápido do que usar charAtcom strings no IE (embora haja alguma sobrecarga inicial quando splité chamado pela primeira vez).

  • Vírgulas antes do final dos objetos: por exemplo, {'foo': 'bar',}não são permitidas no IE.


Problemas específicos do elemento:

  • Obtendo o documentde um IFrame :

    • Firefox e IE8 +: IFrame.contentDocument (o IE passou a oferecer suporte a partir da versão 8 ).
    • IE: IFrame.contentWindow.document
    • ( IFrame.contentWindowrefere-se a windowem ambos os navegadores).

  • Canvas: as versões do IE antes do IE9 não suportam o <canvas>elemento. O IE oferece suporte a VML, que é uma tecnologia semelhante, e o explorercanvas pode fornecer um wrapper local para <canvas>elementos de muitas operações. Esteja ciente de que o IE8 no modo de conformidade com os padrões é muitas vezes mais lento e tem muito mais falhas do que no modo quirks ao usar VML.

  • SVG: IE9 oferece suporte nativo a SVG. O IE6-8 pode suportar SVG, mas apenas com plug - ins externos, com apenas alguns desses plug-ins com suporte para manipulação de JavaScript.

  • <audio>e <video>: são suportados apenas no IE9.

  • Criação dinâmica de botões de opção: o IE <8 tem um bug que torna os botões de opção criados com não document.createElementverificáveis. Veja também Como você cria dinamicamente um botão de rádio em Javascript que funciona em todos os navegadores? para encontrar uma maneira de contornar isso.

  • JavaScript embutido em <a href>tags e onbeforeunloadconflitos no IE: Se houver JavaScript embutido na hrefparte de uma atag (por exemplo <a href="javascript: doStuff()">, o IE sempre mostrará a mensagem retornada onbeforeunload, a menos que o onbeforeunloadmanipulador seja removido antes. Consulte também Solicitar confirmação ao fechar uma guia .

  • <script>diferenças de evento de tag: onsuccess e onerrornão são compatíveis com o IE e são substituídos por um específico do IE onreadystatechangeque é disparado independentemente de o download ter sido bem-sucedido ou não. Veja também JavaScript Madness para mais informações.


Tamanho / posição / rolagem do elemento e posição do mouse:

  • Obtendo o tamanho / posição do elemento : largura / altura dos elementos às vezes é elm.style.pixelHeight/Widthno IE em vez de elm.offsetHeight/Width, mas nenhum é confiável no IE, especialmente no modo quirks, e às vezes um dá um resultado melhor do que o outro.

    elm.offsetTope elm.offsetLeftmuitas vezes são relatados incorretamente, levando à localização incorreta dos elementos, razão pela qual os elementos pop-up etc. estão alguns pixels fora em muitos casos.

    Observe também que se um elemento (ou um pai do elemento) tiver um displayde none, o IE gerará uma exceção ao acessar os atributos de tamanho / posição em vez de retornar 0como o Firefox faz.

  • Obtenha o tamanho da tela (Obtendo a área visível da tela):

    • Raposa de fogo: window.innerWidth/innerHeight
    • Modo de padrões do IE: document.documentElement.clientWidth/clientHeight
    • Modo quirks do IE: document.body.clientWidth/clientHeight

  • Posição de rolagem do documento / posição do mouse : Esta realmente não é definida pelo w3c, portanto, não é padrão, mesmo no Firefox. Para encontrar o scrollLeft/ scrollTopdo document:

    • Firefox e IE em modo quirks: document.body.scrollLeft/scrollTop
    • IE em modo padrão: document.documentElement.scrollLeft/scrollTop
    • NOTA: Alguns outros navegadores usam pageXOffset/ pageYOffsettambém.

      function getDocScrollPos() {
       var x = document.body.scrollLeft ||
               document.documentElement.scrollLeft ||
               window.pageXOffset || 0,
           y = document.body.scrollTop ||
               document.documentElement.scrollTop ||
               window.pageYOffset || 0;
       return [x, y];
      };

    Para obter a posição do cursor do mouse, evt.clientXe evt.clientYem mousemoveeventos dará a posição relativa ao documento sem adicionar a posição de rolagem, portanto, a função anterior deverá ser incorporada:

    var mousepos = [0, 0];
    document.onmousemove = function(evt) {
     evt = evt || window.event;
     if (typeof evt.pageX != 'undefined') {
      // Firefox support
      mousepos = [evt.pageX, evt.pageY];
     } else {
      // IE support
      var scrollpos = getDocScrollPos();
      mousepos = [evt.clientX+scrollpos[0], evt.clientY+scrollpos[1]];
     };
    };

Seleções / intervalos:

  • <textarea>e <input>seleções : selectionStarte selectionEndnão são implementados no IE, e há um sistema de "intervalos" proprietário em seu lugar, consulte também Posição do cursor em textarea, em caracteres desde o início .

  • Obtendo o texto atualmente selecionado no documento:

    • Raposa de fogo: window.getSelection().toString()
    • IE: document.selection.createRange().text


Obtendo elementos por ID:

  • document.getElementByIdtambém pode se referir ao nameatributo em formulários (dependendo do que for definido primeiro no documento), portanto, é melhor não ter elementos diferentes que tenham o mesmo namee id. Isso remonta aos dias em que idnão era um padrão w3c. document.all( uma propriedade proprietária específica do IE ) é significativamente mais rápido do que document.getElementById, mas tem outros problemas, pois sempre priorizou nameantes id. Eu pessoalmente uso este código, recorrendo a verificações adicionais apenas para ter certeza:

    function getById(id) {
     var e;
     if (document.all) {
      e = document.all[id];
      if (e && e.tagName && e.id === id) {
       return e;
      };
     };
     e = document.getElementById(id);
     if (e && e.id === id) {
      return e;
     } else if (!e) {
      return null;
     } else {
      throw 'Element found by "name" instead of "id": ' + id;
     };
    };

Problemas com innerHTML somente leitura:

  • O IE não suporta definir o innerHTML de col, colGroup, frameSet, html, head, style, table, tBody, tFoot, tHead, title, e trelementos. Esta é uma função que contorna isso para elementos relacionados à tabela:

    function setHTML(elm, html) {
     // Try innerHTML first
     try {
      elm.innerHTML = html;
     } catch (exc) {
      function getElm(html) {
       // Create a new element and return the first child
       var e = document.createElement('div');
       e.innerHTML = html;
       return e.firstChild;
      };
      function replace(elms) {
       // Remove the old elements from 'elm'
       while (elm.children.length) {
        elm.removeChild(elm.firstChild);
       }
       // Add the new elements from 'elms' to 'elm'
       for (var x=0; x<elms.children.length; x++) {
        elm.appendChild(elms.children[x]);
       };
      };
      // IE 6-8 don't support setting innerHTML for
      // TABLE, TBODY, TFOOT, THEAD, and TR directly
      var tn = elm.tagName.toLowerCase();
      if (tn === 'table') {
       replace(getElm('<table>' + html + '</table>'));
      } else if (['tbody', 'tfoot', 'thead'].indexOf(tn) != -1) {
       replace(getElm('<table><tbody>' + html + '</tbody></table>').firstChild);
      } else if (tn === 'tr') {
       replace(getElm('<table><tbody><tr>' + html + '</tr></tbody></table>').firstChild.firstChild);
      } else {
       throw exc;
      };
     };
    };

    Observe também que o IE requer a adição de a <tbody>a <table>antes de anexar <tr>s a esse <tbody>elemento ao criar usando document.createElement, por exemplo:

    var table = document.createElement('table');
    var tbody = document.createElement('tbody');
    var tr = document.createElement('tr');
    var td = document.createElement('td');
    table.appendChild(tbody);
    tbody.appendChild(tr);
    tr.appendChild(td);
    // and so on

Diferenças de evento:

  • Obtendo a eventvariável: os eventos DOM não são passados ​​para funções no IE e são acessíveis como window.event. Uma forma comum de obter o evento é usar, por exemplo,
    elm.onmouseover = function(evt) {evt = evt||window.event}
    qual padrão é window.eventif evté indefinido.

  • Principais diferenças de código de evento: os códigos de evento-chave variam muito, embora se você olhar para Quirksmode ou JavaScript Madness , dificilmente será específico para o IE, Safari e Opera são diferentes novamente.

  • Diferenças de eventos do mouse: o buttonatributo no IE é um sinalizador de bits que permite vários botões do mouse ao mesmo tempo:

    • Esquerda: 1 ( var isLeft = evt.button & 1)
    • Direito: 2 ( var isRight = evt.button & 2)
    • Centro: 4 ( var isCenter = evt.button & 4)

      O modelo W3C (compatível com Firefox) é menos flexível do que o modelo IE, com apenas um único botão permitido por vez com esquerda como 0, direita como 2e centro como 1. Observe que, como Peter-Paul Koch menciona , isso é muito contra-intuitivo, pois 0geralmente significa 'sem botão'.

      offsetXe offsetYsão problemáticos e provavelmente é melhor evitá-los no IE. Uma maneira mais confiável de obter o offsetXe offsetYno IE seria obter a posição do elemento relativamente posicionado e subtraí-lo de clientXe clientY.

      Observe também que, no IE, para obter um clique duplo em um clickevento, você precisa registrar um evento clicke dblclickem uma função. O Firefox dispara clicke também dblclickquando clica duas vezes, portanto, a detecção específica do IE é necessária para ter o mesmo comportamento.

  • Diferenças no evento modelo de manipulação: Tanto o modelo IE proprietário e o modelo de manipulação de apoio Firefox de eventos a partir da parte inferior para cima, por exemplo, se existem eventos em ambos os elementos de <div><span></span></div>eventos, em seguida, irá desencadear na span então a divvez da ordem que eles são vinculado se um tradicional por exemplo elm.onclick = function(evt) {}foi usado.

    Os eventos de "captura" geralmente são suportados apenas no Firefox etc, o que acionará divos spaneventos em uma ordem de cima para baixo. O IE tem elm.setCapture()e elm.releaseCapture()para redirecionar eventos do mouse do documento para o elemento ( elmneste caso) antes de processar outros eventos, mas eles têm uma série de problemas de desempenho e, portanto, devem ser evitados.

    • Raposa de fogo:

      Anexar : elm.addEventListener(type, listener, useCapture [true/false])
      Desanexar : elm.removeEventListener(type, listener, useCapture)
      ( typeé, por exemplo, 'mouseover'sem o on)

    • IE: apenas um único evento de um determinado tipo em um elemento pode ser adicionado no IE - uma exceção é levantada se mais de um evento do mesmo tipo for adicionado. Observe também que thisse refere a em windowvez de ao elemento vinculado em funções de evento (portanto, é menos útil):

      Anexar : elm.attachEvent(sEvent, fpNotify)
      Desanexar : elm.detachEvent(sEvent, fpNotify)
      ( sEventé por exemplo 'onmouseover')

  • Diferenças de atributo do evento:

    • Impeça que os eventos sejam processados ​​por qualquer outra função de escuta :

      Firefox: evt.stopPropagation()
      IE: evt.cancelBubble = true

    • Impeça, por exemplo, que eventos importantes insiram caracteres ou que as caixas de seleção sejam marcadas:

      Firefox: evt.preventDefault()
      IE: evt.returnValue = false
      Nota: Apenas retornando falseem keydown, keypress, mousedown, mouseup, clicke resettambém evitar padrão.

    • Obtenha o elemento que acionou o evento:

      Firefox: evt.target
      IE: evt.srcElement

    • Obtendo o elemento do qual o cursor do mouse se afasta: evt.fromElement no IE é evt.targetno Firefox, se em um onmouseoutevento, caso contrárioevt.relatedTarget

    • Obtendo o elemento para o qual o cursor do mouse se move: evt.toElement no IE é evt.relatedTargetno Firefox, se em um onmouseoutevento, caso contrárioevt.target

    • Nota: evt.currentTarget (o elemento ao qual o evento foi vinculado) não tem equivalente no IE.

crio
fonte
12
Lista muito, muito, muito boa! Obrigado a todos que contribuíram :)
cwap
26

Verifique também se há vírgulas como essas ou semelhantes, se houver, em seu código

var o={
'name1':'value1',
'name2':'value2',
} 

a última vírgula (seguindo o valor 2) será tolerada pelo Firefox, mas não pelo IE

Luca Rocchi
fonte
1
A maioria dos bons editores deve pegar este
SeanJA,
1
+1, eu tinha este com muita frequência.
David V.
1
Eu daria a você +10 se pudesse - isso acontece comigo o tempo todo.
Josh,
Ah, e para adicionar ao comentário de @SeanJA: recentemente mudei para o NetBeans que capta isso.
Josh,
Eu perdi muitas horas nisso nas primeiras vezes que fiz algum trabalho de JS. Agora é a primeira coisa que verifico! Amaldiçoe as expansões do Textmate ruins, deixando vírgulas.
Agos
12

Se você continuar usando jQuery ou YUI como sua postagem é marcada, você deve ter diferenças mínimas entre os navegadores ... é para isso que servem as estruturas, para cuidar dessas diferenças entre navegadores para você.

Por exemplo, olhe para a página de travessia do DOM quirksmode , de acordo com ela, o IE não suporta a maioria das coisas ... embora seja verdade, os frameworks sim, por exemplo, o IE não suporta elem.childElementCount, mas em jQuery: $(elem).children().size()funciona para obter este valor, em cada navegador. Você descobrirá que há algo na biblioteca para lidar com 99% dos casos não suportados entre navegadores, pelo menos com script ... com CSS você pode ter que mover para plug-ins para a biblioteca, um exemplo comum disso é obter cantos arredondados trabalhando no IE ... já que não tem suporte CSS para tal.

No entanto, se você começar a fazer as coisas diretamente, por exemplo document.XXX(thing), não está na biblioteca, está fazendo javascript diretamente (é tudo javascript, mas você entendeu :), e isso pode ou não causar problemas, dependendo de como bêbado que a equipe do IE estava ao implementar essa função específica.

Com o IE, é mais provável que você falhe em estilizar corretamente do que problemas brutos de javascript, animações com alguns pixels de diferença e esse tipo de coisa, muito mais no IE6, é claro.

Nick Craver
fonte
Eu entendo melhor agora. Sim, eu também fiz essas coisas diretamente. karlthorwald
user89021
1
Se estiver usando um IDE como o Netbeans, você pode definir os navegadores de destino para o seu javascript e isso também ajudará avisando quando você fizer algo que não parece ser compatível.
SeanJA,
10

getElementbyID também corresponderá ao atributo name no IE, mas não em outros navegadores, e o IE selecionará o que encontrar primeiro.

exemplo:

<script>
 var foo = document.getElementById('bar');
</script>

....
<input name="bar" type="text" />  //IE will get this element
<span id="bar"> Hello, World! </span>  //FF,Safari,Chrome will get this element
GSto
fonte
3
desculpe por ser rude, mas o IE é realmente feio
user89021
12
document.getElementByIdOrNameIGuessWhateverMan (id);
JulianR
5

Existem muitas coisas, mas uma armadilha que eu costumava cair era que muitos navegadores aceitam JSON sem nomes entre aspas, enquanto ie6 e ie7 não.

{ name: "Jakob" } // will often work, but not in ie6/ie7
{ "name": "Jakob" } // Better!

Editar : para esclarecer, este é um problema apenas quando o JSON real é necessário, ao contrário de um literal de objeto. JSON é um subconjunto da sintaxe literal do objeto e é um formato de troca de dados (como XML), por isso é projetado para ser mais seletivo.

Jakob
fonte
2
Observe que isso depende do contexto, um literal de objeto é bom, JSON não ... mas por exemplo o jQuery não permite JSON inválido em sua versão mais recente.
Nick Craver
Não é meu voto negativo ... mas você deve esclarecer isso para os outros, em seguida, +1 meu
Nick Craver
5

Suporte para JavaScript diferente

O IE não oferece suporte (a maioria) às extensões adicionadas ao JavaScript desde 1.5.

Novo em 1.6

  • Métodos de Array - indexOf(), lastIndexOf(), every(), filter(), forEach(), map(),some()
  • for each ... in - itera valores em vez de nomes de propriedades.

Novo em 1.7

Novo em 1.8

  • Métodos Array - reduce(),reduceRight()
  • Atalhos para definir funções.

Algumas dessas coisas exigem que você especifique um número de versão do JavaScript para a execução (que quebrará no IE), mas algumas coisas como [1,2,3].indexOf(2)podem não parecer tão grandes, até que você tente executá-lo no IE

gnarf
fonte
1
o JavaScript de que você está falando aqui é o JavaScript (TM) da mozilla, não o javascript no sentido mais genérico. Nem todas as implementações ECMAScript / motores javascript (MS JScript neste caso) devem seguir o JavaScript (TM) da mozilla. ECMAScript é o padrão, não JavaScript (TM) e JavaScript (TM) não é javascript. Espero que tenha feito sentido.
Dagg Nabbit
Faz sentido para mim, mas em uma discussão sobre compatibilidade entre JavaScript e JScript, imaginei que já seria entendido :)
gnarf
Quando você diz "O IE não suporta (a maioria) as extensões adicionadas ao JavaScript desde 1.5.", Parece que você está dizendo que o JavaScript (TM) do mozilla é um padrão ao qual o IE deve aderir, quando é claro que não é. Você poderia pelo menos dizer JavaScript do Mozilla ou similar ... outro navegador não suporta todas as extensões do Mozilla para ECMAScript como atribuição de desestruturação, etc. A questão era sobre diferenças entre 'mais' javascripte (a implementação específica) JScript, não diferenças entre Mozilla JavaScript(TM)eJScript . Pode ser melhor mostrar onde o IE se desvia do ES.
Dagg Nabbit
3

As principais diferenças entre o JavaScript no IE e o JavaScript nos navegadores modernos (por exemplo, Firefox) podem ser atribuídas às mesmas razões por trás das diferenças no navegador cruzado CSS / (X) HTML. Antigamente não havia um padrão de fato; O IE / Netscape / Opera travou uma guerra de territórios, implementando a maioria das especificações, mas também omitindo algumas, bem como fazendo especificações proprietárias para obter vantagens umas sobre as outras. Eu poderia continuar, mas vamos pular para o lançamento do IE8: JavaScript foi evitado / desprezado por anos, e com a ascensão do FF e o desprezo do webcomm, o IE escolheu se concentrar principalmente no avanço de seu CSS a partir do IE6. E basicamente deixou o suporte DOM para trás. O suporte ao DOM do IE8 também pode ser o do IE6, que foi lançado em 2001 ... então o suporte ao DOM do IE está quase uma década atrás dos navegadores modernos. Se você tiver discrepâncias de JavaScript específicas para um mecanismo de layout, sua melhor aposta é atacá-lo da mesma forma que enfrentamos os problemas de CSS; Visando esse navegador. NÃO USE SNIFFING DE NAVEGADOR, use detecção de recursos para detectar seu navegador / seu nível de suporte DOM.

JScript não é a implementação de ECMAScript do IE; JScript foi a resposta do IE ao JavaScript da Netscape, ambos surgindo antes do ECMAScript.

No que diz respeito aos atributos de tipo no elemento de script, type = "text / javascript" é o padrão padrão (pelo menos em HTML5), então você nunca precisa de um atributo de tipo, a menos que seu script não seja JavaScript.

Quanto ao IE não suportar innerHTML ... innerHTML foi inventado pelo IE e ainda hoje NÃO é um padrão DOM. Outros navegadores o adotaram porque é útil, e é por isso que você pode usá-lo em vários navegadores. No que diz respeito à alteração dinâmica de tabelas, o MSDN diz "por causa da estrutura específica exigida pelas tabelas, o innerText e o innerHTML propriedades dos objetos table e tr são somente leitura." Não sei o quanto disso era verdade inicialmente, mas claramente os navegadores modernos descobriram enquanto lidavam com as complexidades do layout de tabelas.

Eu recomendo fortemente a leitura de PPK em JavaScript Jeremy Keith's DOM Scripting JavaScript de Douglas Crockford : The Good Parts e Christian Hellman's Beginning JavaScript with DOM Scripting e Ajax para obter um forte domínio sobre JavaScript.

No que diz respeito a Frameworks / Bibliotecas, se você ainda não tem um bom domínio de JavaScript, deve evitá-los. 2 anos atrás caí na armadilha do jQuery e, embora fosse capaz de realizar feitos magníficos, nunca aprendi absolutamente nada sobre como codificar JavaScript corretamente. Em retrospecto, o jQuery é um kit de ferramentas DOM incrível, mas minha falha em aprender fechamentos apropriados, herança prototípica, etc., não apenas atrasou meu conhecimento pessoal, mas meu trabalho começou a ter grandes impactos de desempenho porque eu não tinha ideia do que estava fazendo.

JavaScript é a linguagem do navegador; se você é um engenheiro do lado do cliente / front-end, é de extrema importância que você comande o JavaScript. Node.js está trazendo o JavaScript completo, vejo imensos avanços diários em seu desenvolvimento; O JavaScript do lado do servidor será um padrão em um futuro muito próximo. Estou mencionando isso para enfatizar ainda mais o quão importante o JavaScript é agora e será.

JavaScript vai fazer mais ondas do que Rails.

Bom script!

Albert
fonte
2
Boa resposta, embora eu não concorde com o uso de detecção de recursos para detectar o navegador; use a detecção de recursos apenas para testar o suporte a esses recursos. Veja também os exemplos em Detecção de recurso não é detecção de navegador .
Marcel Korpel
meh. concordo totalmente com a sua discordância. obrigado por pegar isso. ainda sou um JavaScript n00b, mas não há vergonha no meu jogo. "A detecção de navegador baseada em recursos é uma prática muito ruim que deve ser evitada a todo custo. A detecção direta de recursos é uma prática recomendada e, em quase todos os casos, é exatamente o que você precisa."
Albert
2

Alguns objetos nativos são somente leitura sem realmente parecerem ser (você pode escrever neles, mas não tem efeito). Por exemplo, um javascript avançado comum é baseado na extensão do Elementobjeto substituindo os métodos do sistema, digamos, alterando Element.prototype.appendChild () para fazer mais do que anexar um nó filho - digamos, inicializá-lo com os dados do pai. Isso falhará silenciosamente no IE6 - o método original será chamado em novos objetos em vez do novo.

Alguns navegadores (não me lembro agora) consideram as novas linhas entre as tags HTML como nós de texto, enquanto outros não. Portanto, childNodes (n), nextSibling (), firstChild () e outros se comportarão de maneira muito diferente.

SF.
fonte
2

Vírgulas finais em matrizes e literais de objeto costumavam ser um problema, não verifiquei recentemente (ou seja, IE8):

var a = [ 1, 2, 3, ];
var o = { a:1, b:2, c:3, };

Isso causaria algum código extra ao gerar tais estruturas do lado do servidor.

npup
fonte
2

Acabei de encontrar um esta manhã, um colega de trabalho definiu a tag de script como: <script type="application/javascript">porque seu preenchimento automático de ide tinha isso antes de "text / javascript"

Mas, acontece que o IE simplesmente ignora o script inteiro se você usar "application / javascript", você precisa usar "text / javascript"

Katjones
fonte
javascript é o padrão em todos os navegadores, então use apenas<script>
Lauri
2

Eu encontrei uma peculiaridade estranho outro dia com o Internet Explorer. Eu estava usando YUI e substituindo o conteúdo de um corpo de tabela () definindo o innerHTML

Y.one('#elementId').set('innerHTML', '<tr><td>Column 1</td></tr>');

Isso funcionaria em todos os navegadores, EXCETO o IE. Finalmente descobri que não era possível substituir o innerHTML de uma tabela no IE. Tive que criar um nó usando YUI e, em seguida, anexar esse nó.

var myNode = Y.node.create('<tr><td>Column 1</td></tr>');
Y.one('#elementId').append(myNode);

Essa foi divertida de descobrir!

Justin
fonte
1
Tenho a sensação de que você precisa embrulhá-lo com <tbody>etiquetas.
Casey Chu
No código original, ele realmente está envolvido em uma tag <tbody>. Ainda me surpreende que o IE não tenha gostado. Lembro-me de ter lido sobre isso nos documentos oficiais da Microsoft, mas não consigo encontrar o link agora. Desculpe!
Justin
1

Vírgulas extras e vírgulas ausentes costumavam ser um problema comum no IE, embora funcione bem no FF.

Deep
fonte
1

O IE é muito rígido quanto à ausência de ";" geralmente é isso.

Sam3k
fonte
Eu encontro muitos deles enquanto estou jsLinting agora. Parece ser um ponto importante.
user89021
1

Pelo que vale a pena, acabei de encontrar esse problema desagradável no <IE9

digamos que você tenha algum html como este:

<table><tr><td>some content...</td></tr></table>

e por algum motivo (eu tive um bom) você precisa recuperar todo o HTML na tabela antes do último TR de fechamento, você pode tentar algo assim:

var tableHtml = document.getElementById('thetable').innerHTML;
var fragment = tableHtml.substring(0, tableHtml.lastIndexOf('</tr>'));

<IE9 não retornará nada (-1) aqui porque a variável tableHtml contém todas as tags html com letras maiúsculas e lastIndexOf diferencia maiúsculas de minúsculas. Para contornar isso, tive que inserir um toLowerCase () antes de lastIndexOf.

tolice
fonte
0

O IE não é um navegador moderno e apenas segue o ECMAScript vagamente.

Roubar
fonte
0

Você mencionou o jQuery, com o qual estou menos familiarizado, mas para referência geral e, especificamente, com Prototype, uma coisa a ser observada são palavras / nomes de métodos reservados no IE. Eu sei o que sempre me incomoda são coisas como:

someElement.appendChild(new Element('label',{ **for**: someInput.id }).update( someLabelText );

(new Element (tagName, propertyHash) é como os novos elementos são criados no Protitype). No IE, for:deve ser 'for':, porque foré uma palavra reservada. O que faz todo o sentido - mas o FireFox irá tolerar isso.

Outro exemplo:

someElement.wrap('div').addClassName('someClass')

(o wrapmétodo em Prototype envolve um elemento em outro) - No IE, em textareas, wrapé uma propriedade e Element.wrap()deve ser usado em vez da versão metodizada

Estes são dois exemplos que me vêm à mente com a minha experiência. Eles são baseados no protótipo, mas o problema principal não é: cuidado com quaisquer métodos / rótulos / identificadores que o IE considera palavras reservadas, mas o FireFox ou Safari toleram.

Josh
fonte
0

O fato é que o IE não suporta JavaScript ... Ele suporta sua própria implementação de ECMAScript: JScript ... que é um pouco diferente ...

xavierm02
fonte
0

Usar console.log()para enviar erros para o console de erro do Firefox fará com que seus scripts falhem no IE. Tenho que lembrar de tirá-los ao testar no IE.

Erikk Ross
fonte
Acredito que usar o console.log também falhará, mesmo no Firefox, se você não tiver o FireBug ativado.
ejel