Bridge para encapsular o Cross Browser

{ October 5th, 2007 }


cmilfont

Autor: cmilfont

No rastro do meu último post, aproveitando a deixa de detecção otimizada trabalhando junto com o Design Pattern Bridge, aproveitaremos esse conceito para encapsularmos a complexidade de se trabalhar com códigos que tenham que rodar em múltiplos Browsers.

O padrão Bridge define o desacoplamento da abstração (interface) com suas implementações e cada implementação possa variar independentemente.

No código passado vimos isso implementado na função addEvent como segue:

var addEvent = function(el, type, fn) {
    el['on'+type] = fn;
};
if(document.addEventListener) {
    addEvent = function(el, type, fn) {
        el.addEventListener(type, fn, false);
    };
} else if(document.attachEvent) {
    addEvent = function(el, type, fn) {
        el.attachEvent('on'+type, fn);
    };
}

Nesse código o método addEvent é uma forma genérica de adicionar eventos a um elemento DOM na página e encapsula o comportamento implementado pelos Browsers. Essa estratégia pode e deve ser adotada em todo o código que necessite de implementação diferente dependendo do navegador, o chamado Cross Browser.

Cross Browser é a técnica de implementar uma construção que rode em múltiplos navegadores sem diferença perceptível ao usuário. O custo de aplicar essa técnica é diminuir a performance da aplicação como um todo, aumentar a complexidade do código mantido, propiciar um ambiente mais sujeito a falhas de implementação e cair em bugs do próprio navegador (como o Memory-Leak no IE).

Instanciar o objeto XMLHttpRequest é outra situação que possui diferença entre o líder de mercado e os demais navegadores. Aplicando essa técnica, faríamos o seguinte código:

var getXHR = function() {
	this.http = new XMLHttpRequest;
	return this.http;
}
var isIE = !!document.attachEvent;
if(isIE) {
      var msxml = [
        'MSXML2.XMLHTTP.3.0',
        'MSXML2.XMLHTTP',
        'Microsoft.XMLHTTP'
      ];
      for (var i=0, len = msxml.length; i < len; ++i) {
        try {
          http = new ActiveXObject(msxml[i]);
          //cria nova implementação
          getXHR = function() {
            return new ActiveXObject(msxml[i]);
          };
          break;
        }
        catch(e) {}
      }
};

Dei a dica no artigo passado de criar um arquivo para cada implementação de navegador diferente e aplicar o conceito de Lazy Loading para carregar sob demanda.

Categories: Ajax, Design Patterns, JavaScript, Melhores práticas ~ ~ Trackback


Assine os comentários deste artigo.


Adicionar ao Rec6

7 Responses to “Bridge para encapsular o Cross Browser”

  1. 1
    Rafael Ponte

    Opa! Excelente post :))

    Hoje com a gama de frameworks/APIs javascripts a preocupação com cross-browser recai bem menos aos desenvolvedores, sorte nossa! Contudo, ainda há várias “gambis” que somos forçados a implementar para que funcione em diveros browsers, rss

  2. 2
    Handerson Frota

    Hum, mas será que seria interessante essa implementação para sistemas mais complexos ?

    Mas parabêns gostei da ideia sim.

  3. 3
    cmilfont

    Sim, construir funções que encapsulem a diferença dos browsers é até melhor para sistemas mais complexos, que precisam fazer essas chamadas o tempo todo e a todo momento voce ter que verificar qual o browser.

  4. 4
    Rafael via Rec6

    Bridge para encapsular o Cross Browser - CMilfont Tech…

    Bridge para encapsular o Cross Browser…

  5. 5
    Rafael Ponte » Blog Archive » Suavizando o load de páginas no Internet Explorer

    [...] do IE, ou seja, não funcionará em outros browsers, talvez abstraindo com algo no estilo bridge poderemos deixar o efeito cross-browser. Se souberem de algo não deixem de [...]

  6. 6
    Resumo javascript - Jan 2008 - CMilfont Tech

    [...] http://www.milfont.org/tech/2007/10/05/bridge-para-encapsular-o-cross-browser/ [...]

  7. 7
    Capturando valores Css dos objetos. « Javiani

    [...] pode ser melhorada, e percebi isso lendo um dos meus blogs favoritos que é o Milfont. O Milfont nesse post falou sobre o design pattern Bridge para encapsular o [...]

Leave a Reply