Object Literal Pattern

Tempo de leitura: 6 min

Escrito por blackzig
em 27/06/2019

O Object Literal Pattern é provavelmente o jeito mais simples encapsular as partes de uma implementação de baixo de um objeto de guarda-chuva que funciona como um Módulo. O nome deste padrão descreve como é utilizado. O desenvolvedor apenas precisa declarar uma variável e nomear um objeto que irá relacionar com todas as partes que forem necessárias encapsuladas dentro deste Módulo.

Vamos criar um Módulo que fornece um único inteiro para uma página, é similar ao que o jquery.guid faz:

var simpleguid = {

            guid: 1,

            init: function(){

                        this.guid = 1;

            },

            increaseCounter: function(){

                        this.guid++;

                        //ou simpleguid.guid++;

            },

            getNext: function(){

                        var nextGuid = this.guid;

                        this.increaseCounter();

                        return nextGuid;

            }

}

Uma simples regra que você pode seguir deste padrão é definir todas as variáveis e funções que cada implementação precisa como as propriedades de um objeto. Nosso código é reutilizável e não polui o Global Namespace, outros podem apenas definir uma simples variável para o nosso Módulo, é o simpleguid neste caso.

Podemos acessar as propriedades internas do Módulo, ou utilizar a keyword this, como a this.guid, ou utilizar o nome completo do Módulo simple.guid. Para utilizar o Módulo do código apresentado, precisamos acessar sua propriedade utilizando o seu nome. Por exemplo, chamando o método simpleguid.getNext() que retornará o próximo número e mudará o estado do Módulo incrementando o seu contador interno.

Um ponto negativo deste padrão é que não fornece nenhuma segurança interna do Módulo. Todas as partes internas do Módulo podem ser acessadas e subscritas por um código externo, apesar que somos nós que escolhermos o que será exposto, como os métodos simpleguid.init() e o simpleguid.next(). Há muitas convenções de como escolher os nomes, pela sua funcionalidade ou adicionando o underscore(_) para os nomes das propriedades que serão utilizadas apenas internamente, mas tecnicamente isto não resolve o ponto negativo.

Outra desvantagem é escrever um Módulo gigante utilizando um objeto literal. É verdade que desenvolvedores JavaScript estão acostumados a terminar suas variáveis com ponto e vírgula(;), e escrevem grandes Módulos utilizando vírgula(,) depois de cada propriedade, que facilmente pode levar a erros de sintaxe.

Apesar deste padrão torna fácil a declaração de Namespaces aninhados para um Módulo, pode acontecer de a estrutura ficar com uma legibilidade ruim, neste caso há a necessidade de criar vários níveis. Vamos ver um exemplo:

var myTodoApp = {

            todos: [],

            addTodo: function(todo) { this.todos.push(todo); },

            getTodos: function() { return this.todos; },

            updateTodo: function(todo) { /*…*/ },

            imports: {

                        fromGDrive: function() { /*…*/ },

                        fromUrl: function() { /*…*/ },

                        fromText: function() { /*…*/ }

            },

            exports: {

                        gDrivePublicKey: ‘#wnanqAASnsmkkw’,

                        toGDrive: function() { /*…*/ },

                        toFile: function() { /*…*/ }

            },

            share: {

                        toTwitter: function(todo) { /*…*/ }

            }

};

Felizmente neste caso pode ser facilmente ajustado, separando o objeto literal em múltiplas assinaturas de submódulos (preferencialmente em arquivos separados):

 var myTodoApp = {

            todos: [],

            addTodo: function(todo) { this.todos.push(todo); },

            getTodos: function() { return this.todos; },

            updateTodo: function(todo) { /*…*/ }

};

/*…*/

myTodoApp.exports = {

            gDrivePublicKey: ‘#wnanqAASnsmkkw’,

            toGDrive: function() { /*…*/ },

            toFile: function() { /*…*/ }

};

/*…*/

😍 Aulas de Javascript – http://bit.ly/blackzigjavascript

jQuery Design Patterns (English Edition)https://amzn.to/2RJaILW

#designpattern #objectliteralpattern

Fonte: Livro jQuery Design Patterns

Você vai gostar também:

Para enviar seu comentário, preencha os campos abaixo:

Deixe um comentário


*


*


Seja o primeiro a comentar!

Damos valor à sua privacidade

Nós e os nossos parceiros armazenamos ou acedemos a informações dos dispositivos, tais como cookies, e processamos dados pessoais, tais como identificadores exclusivos e informações padrão enviadas pelos dispositivos, para as finalidades descritas abaixo. Poderá clicar para consentir o processamento por nossa parte e pela parte dos nossos parceiros para tais finalidades. Em alternativa, poderá clicar para recusar o consentimento, ou aceder a informações mais pormenorizadas e alterar as suas preferências antes de dar consentimento. As suas preferências serão aplicadas apenas a este website.

Cookies estritamente necessários

Estes cookies são necessários para que o website funcione e não podem ser desligados nos nossos sistemas. Normalmente, eles só são configurados em resposta a ações levadas a cabo por si e que correspondem a uma solicitação de serviços, tais como definir as suas preferências de privacidade, iniciar sessão ou preencher formulários. Pode configurar o seu navegador para bloquear ou alertá-lo(a) sobre esses cookies, mas algumas partes do website não funcionarão. Estes cookies não armazenam qualquer informação pessoal identificável.

Cookies de desempenho

Estes cookies permitem-nos contar visitas e fontes de tráfego, para que possamos medir e melhorar o desempenho do nosso website. Eles ajudam-nos a saber quais são as páginas mais e menos populares e a ver como os visitantes se movimentam pelo website. Todas as informações recolhidas por estes cookies são agregadas e, por conseguinte, anónimas. Se não permitir estes cookies, não saberemos quando visitou o nosso site.

Cookies de funcionalidade

Estes cookies permitem que o site forneça uma funcionalidade e personalização melhoradas. Podem ser estabelecidos por nós ou por fornecedores externos cujos serviços adicionámos às nossas páginas. Se não permitir estes cookies algumas destas funcionalidades, ou mesmo todas, podem não atuar corretamente.

Cookies de publicidade

Estes cookies podem ser estabelecidos através do nosso site pelos nossos parceiros de publicidade. Podem ser usados por essas empresas para construir um perfil sobre os seus interesses e mostrar-lhe anúncios relevantes em outros websites. Eles não armazenam diretamente informações pessoais, mas são baseados na identificação exclusiva do seu navegador e dispositivo de internet. Se não permitir estes cookies, terá menos publicidade direcionada.

Visite as nossas páginas de Políticas de privacidade e Termos e condições.

Importante: Este site faz uso de cookies que podem conter informações de rastreamento sobre os visitantes.
Criado por WP RGPD Pro

Aprenda a Criar e Programar Jogos Completos em 2D e 3D!

Seja um Desenvolvedor de Jogos Profissional