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

Liga das Nações 2020/21

França vira contra Suécia e vence por 4 a 2 na Liga das Nações

França e Suécia se enfrentam pela Liga das Nações - Xavier Laine/Getty Images
França e Suécia se enfrentam pela Liga das Nações Imagem: Xavier Laine/Getty Images

Do UOL, em São Paulo

17/11/2020 19h00

A França derrotou a Suécia por 4 a 2 hoje pela 6ª rodada pela fase de grupos da Liga das Nações. O jogo foi realizado no Stade de , em Saint-Denis.

Viktor Claesson abriu o placar para os suecos aos 4 minutos do primeiro tempo. Claesson pegou a sobra na entrada da área, escapou da marcação e finalizou. A bola desviou em Varane e morreu no canto esquerdo de Lloris.

A França empatou com Olivier Giroud, aos 16 minutos do primeiro tempo. Thuram encarou a marcação do lado esquerdo e tocou para Giroud, que finalizou forte e empatou o jogo.

Benjamin Pavard virou o jogo aos 35 minutos do primeiro tempo. Thuram girou diante da marcação dentro da área, buscando uma jogada individual. A bola rebateu e sobrou com Pavard, que, de primeira, finalizou no canto direito de Olsen.

Aos 14 minutos do segundo tempo, Olivier Giroud ampliou. Mbappé cruzou na área para Giroud, que cabeceou firme, no canto direito de Olsen.

A Suécia ainda diminuiu com Robin Quaison, aos 43 minutos do segundo tempo. Kulusevski fez um e para Bengtsson, que cruzou. Quaison recebeu e completou para as redes.

Mas Kingsley Coman sacramentou a vitória, aos 49 minutos do segundo tempo. Em contra-ataque, Coman recebeu na frente e, sem goleiro, finalizou de fora da área.

FICHA TÉCNICA FRANÇA X SUÉCIA

Local: Stade de , Saint-Denis

Data: 17 de novembro de 2020, terça-feira

Horário: 16h45 (de Brasília)

Árbitro: Aleksei Kulbakov

Assistentes: Dmitry Zhuk e Oleg Maslyanko

Cartões amarelos: Kristoffer Olsson (Suécia)

Gols: Olivier Giroud, aos 16 minutos do primeiro tempo; Benjamin Pavard, aos 35 minutos do primeiro tempo; Olivier Giroud, aos 14 minutos do segundo tempo e Kingsley Coman, aos 49 minutos do segundo tempo (França);Viktor Claesson, aos 4 minutos do primeiro tempo e Robin Quaison, aos 43 minutos do segundo tempo (Suécia)

FRANÇA: Hugo Lloris; Benjamin Pavard; Raphaël Varane; Presnel Kimpembe; Lucas Hernández; Adrien Rabiot; Paul Pogba; Moussa Sissoko; Marcus Thuram; Antoine Griezmann; Olivier Giroud. Técnico: Didier Deschamps.

SUÉCIA: Robin Olsen; Mikael Lustig; Victor Lindelöf; Marcus Danielson; Pierre Bengtsson; Kristoffer Olsson; Viktor Claesson; Emil Forsberg; Jordan Larsson; Marcus Berg; Dejan Kulusevski. Técnico: Janne Andersson.

Este conteúdo foi gerado pelo sistema de produção automatizada de notícias do UOL e revisado pela redação antes de ser publicado.