Logo

dev-resources.site

for different kinds of informations.

WTF é gzipping (e como é diferente da minificação)?

Published at
12/3/2023
Categories
javascript
programming
portugues
Author
dougsource
Categories
3 categories in total
javascript
open
programming
open
portugues
open
Author
10 person written this
dougsource
open
WTF é gzipping (e como é diferente da minificação)?

Nota: apenas traduzi o texto abaixo e postei aqui.

Gzipping

O formato .gzip é um formato de arquivo compactado, muito parecido com .zip. Reduz o tamanho dos seus arquivos em, em média, 70%. Isso é muita coisa!

Gzipping um arquivo significa enviá-lo neste formato compactado.

O legal dos arquivos compactados é que eles podem ser enviados compactados nesse formato a partir do server, e os navegadores podem descompactá-los e executá-los "on-the-fly". Mesmo que isso envolva algum trabalho para o navegador, pois quanto reduz o tamanho dos arquivos, tem uma melhoria dramática no desempenho.

O HTML, CSS e JavaScript combinados para um projetos JavaScript comum tem, por exemplo, 37,9kb. São três HTTP requests de ida e volta.

Após gzipping, o tamanho total é de apenas 11,4 KB, uma única request. Isso é uma redução enorme no tamanho.

Como gzip seus arquivos

Você pode ativar o gzipping em seu server.

Caso seu site esteja hospedado em um Apache server, você precisará modificar seu arquivo .htaccess. O HTML5 Boilerplate possui a configuração mais abrangente.

Com o ngingx, você precisará modificar seu arquivo de configuração.

Você pode testar se o gzipping está habilitado abrindo a aba Network nas developer tools do seu navegador. Cada recurso mostrará dois números: o tamanho real e o tamanho transferido.

Se o tamanho transferido for menor (em um valor significativo), gzip será ativado.

No entanto, certifique-se de verificar o botão Disable cache antes de testar.

Minificação

Minificação é o processo de remoção de comentários e espaços em branco do seu código.

Minificadores modernos, como TerserJS, também reescrevem nomes de variáveis para torná-los tão pequenos quanto possível e, às vezes, também fazem outras otimizações.

Por exemplo, digamos que você passou um código como este (não está bem otimizado):

/**
 * Soma um ou mais numbers juntos
 * @param  {Number} Os numbers para somar
 * @return {Number} O total
 */
var add = function () {
    // Converte o object arguments para um array
    var numbers = Array.prototype.slice.call(arguments);

    // Configura o total
    var total = 0;

    // Itera cada number e soma ele ao total
    numbers.forEach(function (number) {
        total = total + number;
    });

    return total;
};

Enter fullscreen mode Exit fullscreen mode

Terser retornaria algo assim:

var add=function(){var r=Array.prototype.slice.call(arguments),a=0;return r.forEach(function(r){a+=r}),a};
Enter fullscreen mode Exit fullscreen mode

Como você pode ver, todos os comentários desapareceram. As variáveis internas como numbers e total foram renomeadas (r e a, respectivamente, neste caso).

Mesmo total = total + number foi reescrito para total += number (quando então se torna a+=r após as variáveis serem renomeadas).

A quantidade de minificação de bytes que você economiza pode variar muito, dependendo de quanto seu código pode ser otimizado e de quão liberal você é em relação a comentários e espaços em branco.

Eu otimizo meu código para facilitar a leitura em vez da brevidade, portanto, um minificador economiza muito tamanho de arquivo. Sua milhagem pode variar.

Como minificar seu código

Você pode usar uma ferramenta de linha de comando como o Terser. Ou você pode usar uma GUI como CodeKit ou Prepros.

Todos eles fazem mais ou menos a mesma coisa, então escolha aquele com o qual você se sente mais confortável.

Você deve gzipping, minificar, ou ambos?

Alguns desenvolvedores dizem que gzipping tem muito mais impacto do que minificar que a minificação não vale a pena.

Sim, gzipar tem um impacto muito maior do que minificar. Mas os arquivos compactados e minificados são sempre menores do que aqueles apenas gzipped. É o suficiente para fazer a diferença? Depende.

Eu fiz alguns testes sobre isso no ano passado. Minha principal conclusão foi que se você se preocupa com o desempenho, sempre faça as duas coisas.

Fonte

Newsletter de Go Make Things

portugues Article's
30 articles in total
Favicon
Validação e Sanitização em Aplicações Web
Favicon
Golang básico - Comparação de Igualdade
Favicon
Guia de React re-render: tudo, tudo de uma vez
Favicon
Go + hot reload
Favicon
Como animar o scrolling para anchor links com CSS
Favicon
Como criar uma sticky navigation apenas com CSS
Favicon
Como usar requestAnimationFrame() com vanilla JS
Favicon
Como atualizar a URL do navegador sem refresh a página usando a vanilla JS History API
Favicon
Por que utilizar um elemento form quando submit campos com JavaScript?
Favicon
Quando um framework é melhor que a manipulação nativa do DOM
Favicon
Recursão com vanilla JavaScript
Favicon
Como usar async e await com vanilla JavaScript
Favicon
Construindo um show/hide disclosure component acessível com vanilla JS
Favicon
Eu <3 cascade!
Favicon
Você provavelmente não precisa de um DOMContentLoaded event em seu Javacript
Favicon
Formas de escrever Immediately Invoked Function Expression (IIFE) no JavaScript
Favicon
Event delegation e múltiplos seletores com vanilla JS
Favicon
Usando a propriedade CSS currentColor para contruir componentes extensíveis
Favicon
CurrentColor e SVGs
Favicon
WTF é gzipping (e como é diferente da minificação)?
Favicon
Como eu estruturo meus projetos vanilla JS
Favicon
Uma alternativa vanilla JS para o método moment.js timeFromNow()
Favicon
Recriando o método lodash partition() em vanilla JS
Favicon
Recriando o método lodash inRange() em vanilla JS
Favicon
Recriando o método lodash pull() em vanilla JS
Favicon
Como converter segundos para minutos e horas em vanila JS
Favicon
Gerando números randômicos com vanila JS
Favicon
Obtendo os meses formatados com vanila JS
Favicon
Como ser um desenvolvedor mais produtivo
Favicon
Como construir um site que carregue em menos de um segundo

Featured ones: