;(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

Son se emociona com Coreia nas oitavas: 'Esperei tanto por esse momento'

02/12/2022 16h31

Classificação e Jogos

Com uma classificação heroica, a Coreia do Sul venceu Portugal por 2 a 1 e teve que 'secar' o Uruguai nos minutos finais. Os sul-americanos não conseguiram marcar o terceiro gol e deram adeus à Copa. Craque do time e dono da assistência decisiva, Son chorou na entrevista após o jogo.

"Esperei tanto por este momento. Eu sabia que nossos jogadores poderiam fazer isso. Eles jogaram melhor do que eu esperava. Eu era o capitão, mas não joguei tão bem quanto esperava, mas fiquei grato que os outros jogadores cobriram minhas deficiências. Estou muito orgulhoso deles. Acho que os jogadores tiveram energia extra para correr mais graças ao apoio dos torcedores. Acho que foi por isso que conseguimos jogar bem. Eu gostaria de parabenizar a todos os jogadores ao invés de mim", disse.

O craque estava na lista do Mundial da Rússia, em 2018, quando a Coreia do Sul surpreendeu ao derrotar e eliminar a poderosa Alemanha. Contudo, a seleção não avançou em seu grupo. Apesar da dificuldade, os sul-coreanos conseguiram se superar e carimbar a vaga nesta sexta.

"Em primeiro lugar, foi um jogo difícil, como esperávamos. Foi uma partida muito difícil, especialmente depois de sofrer o primeiro gol. Mas os jogadores correram a mais, nunca desistindo. Todos eles se sacrificaram. Graças a isso, acho que conseguimos um bom resultado. Demos o nosso melhor em 2018 também, mas não conseguimos um resultado como este. Estou tão feliz que, desta vez, também conseguimos o resultado. Estou tão orgulhoso dos nossos jogadores", completou Son.

A Coreia enfrenta o Brasil nas oitavas de finais. O duelo está marcado para a próxima segunda-feira, às 16h (de Brasília), no estádio 974.

Qual a grande decepção da Copa do Mundo na 1ª fase?

Resultado parcial

Total de 2760 votos
58,70%
Thaier Al-Sudani/Reuters