;(function() { window.createMeasureObserver = (measureName) => { var markPrefix = `_uol-measure-${measureName}-${new Date().getTime()}`; performance.mark(`${markPrefix}-start`); return { end: function() { performance.mark(`${markPrefix}-end`); performance.measure(`uol-measure-${measureName}`, `${markPrefix}-start`, `${markPrefix}-end`); performance.clearMarks(`${markPrefix}-start`); performance.clearMarks(`${markPrefix}-end`); } } }; /** * Gerenciador de eventos */ window.gevent = { stack: [], RUN_ONCE: true, on: function(name, callback, once) { this.stack.push([name, callback, !!once]); }, emit: function(name, args) { for (var i = this.stack.length, item; i--;) { item = this.stack[i]; if (item[0] === name) { item[1](args); if (item[2]) { this.stack.splice(i, 1); } } } } }; var runningSearch = false; var hadAnEvent = true; var elementsToWatch = window.elementsToWatch = new Map(); var innerHeight = window.innerHeight; // timestamp da última rodada do requestAnimationFrame // É usado para limitar a procura por elementos visíveis. var lastAnimationTS = 0; // verifica se elemento está no viewport do usuário var isElementInViewport = function(el) { var rect = el.getBoundingClientRect(); var clientHeight = window.innerHeight || document.documentElement.clientHeight; // renderizando antes, evitando troca de conteúdo visível no chartbeat-related-content if(el.className.includes('related-content-front')) return true; // garante que usa ao mínimo 280px de margem para fazer o lazyload var margin = clientHeight + Math.max(280, clientHeight * 0.2); // se a base do componente está acima da altura da tela do usuário, está oculto if(rect.bottom < 0 && rect.bottom > margin * -1) { return false; } // se o topo do elemento está abaixo da altura da tela do usuário, está oculto if(rect.top > margin) { return false; } // se a posição do topo é negativa, verifica se a altura dele ainda // compensa o que já foi scrollado if(rect.top < 0 && rect.height + rect.top < 0) { return false; } return true; }; var asynxNextFreeTime = () => { return new Promise((resolve) => { if(window.requestIdleCallback) { window.requestIdleCallback(resolve, { timeout: 5000, }); } else { window.requestAnimationFrame(resolve); } }); }; var asyncValidateIfElIsInViewPort = function(promise, el) { return promise.then(() => { if(el) { if(isElementInViewport(el) == true) { const cb = elementsToWatch.get(el); // remove da lista para não ser disparado novamente elementsToWatch.delete(el); cb(); } } }).then(asynxNextFreeTime); }; // inicia o fluxo de procura de elementos procurados var look = function() { if(window.requestIdleCallback) { window.requestIdleCallback(findByVisibleElements, { timeout: 5000, }); } else { window.requestAnimationFrame(findByVisibleElements); } }; var findByVisibleElements = function(ts) { var elapsedSinceLast = ts - lastAnimationTS; // se não teve nenhum evento que possa alterar a página if(hadAnEvent == false) { return look(); } if(elementsToWatch.size == 0) { return look(); } if(runningSearch == true) { return look(); } // procura por elementos visíveis apenas 5x/seg if(elapsedSinceLast < 1000/5) { return look(); } // atualiza o último ts lastAnimationTS = ts; // reseta status de scroll para não entrar novamente aqui hadAnEvent = false; // indica que está rodando a procura por elementos no viewport runningSearch = true; const done = Array.from(elementsToWatch.keys()).reduce(asyncValidateIfElIsInViewPort, Promise.resolve()); // obtém todos os elementos que podem ter view contabilizados //elementsToWatch.forEach(function(cb, el) { // if(isElementInViewport(el) == true) { // // remove da lista para não ser disparado novamente // elementsToWatch.delete(el); // cb(el); // } //}); done.then(function() { runningSearch = false; }); // reinicia o fluxo de procura look(); }; /** * Quando o elemento `el` entrar no viewport (-20%), cb será disparado. */ window.lazyload = function(el, cb) { if(el.nodeType != Node.ELEMENT_NODE) { throw new Error("element parameter should be a Element Node"); } if(typeof cb !== 'function') { throw new Error("callback parameter should be a Function"); } elementsToWatch.set(el, cb); } var setEvent = function() { hadAnEvent = true; }; window.addEventListener('scroll', setEvent, { capture: true, ive: true }); window.addEventListener('click', setEvent, { ive: true }); window.addEventListener('resize', setEvent, { ive: true }); window.addEventListener('load', setEvent, { once: true, ive: true }); window.addEventListener('DOMContentLoaded', setEvent, { once: true, ive: true }); window.gevent.on('allJSLoadedAndCreated', setEvent, window.gevent.RUN_ONCE); // inicia a validação look(); })();
  • AssineUOL
Topo

Real Madrid

Tik Tok, Itália e tutoriais: Entenda a comemoração do gol de Vini Jr.

Vinicius Junior celebra gol do Real Madrid com o "Khaby move" - PABLO MORANO/REUTERS
Vinicius Junior celebra gol do Real Madrid com o 'Khaby move' Imagem: PABLO MORANO/REUTERS

Colaboração para o UOL, em São Paulo

31/10/2021 11h02

Vinícius Jr. foi o grande destaque da vitória do Real Madrid por 2 a 1 sobre o Elche, ontem (30), pelo Campeonato Espanhol. Autor de dois gols, o atacante brasileiro comemorou o primeiro deles de uma forma curiosa: estendendo os braços, com as mãos abertas, como se dissesse 'pronto' e com uma expressão engraçada, deixando os lábios em evidência. Em suas redes sociais, o próprio Vin Jr explicou.

O gesto, conhecido como 'Khaby Move' é a marca pela qual ficou conhecido o tiktoker senegalês Khaby Lame, que vive na Itália e é uma das maiores estrelas da rede social de vídeos, com mais de 100 milhões de seguidores e de 1,5 bilhão de curtidas na rede social de vídeos. Hoje, ele tem o segundo perfil com mais fãs no Tik Tok.

Khaby Lame ficou famoso por satirizar tutoriais da internet, mostrando como algumas tarefas ensinadas nestes vídeos poderiam ser feitas de maneira bem mais simples. Ele sempre encerra seus vídeos com o 'Khaby Move'.

Vini Jr não é o primeiro

Fã de futebol, Khaby Lame já fez vários vídeos com personalidades do esporte e viu o seu gesto ser reproduzido em comemorações de jogadores como Mbappé e Achraf Hakimi, do PSG, e Pogba, do Manchester United.

O tiktoker também é fã do futebol de Vini Jr e já ganhou até uma camisa autografada do jogador do Real Madrid em setembro, quando a equipe espanhola visitou a Inter de Milão e venceu por 1 a 0, em jogo pelo Grupo D da Liga dos Campeões da Europa.

Classificação do Espanhol

Com a vitória sobre o Elche, ontem (30), o Real Madrid chegou a 24 pontos em 11 jogos e assumiu a liderança provisória do Campeonato Espanhol, com a mesma pontuação de Sevilla e Real Sociedad - que ainda joga na rodada.

Real Madrid