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

São Paulo

São Paulo domina, goleia o Mirassol e está na final do Paulistão

Colaboração para o UOL, em Belo Horizonte

16/05/2021 22h23

O São Paulo está classificado para a final do Campeonato Paulista. Neste domingo (16), o Tricolor não tomou conhecimento do Mirassol e goleou, por 4 a 0, a equipe do interior paulista. Arboleda, Pablo, Gabriel Sara e Luciano foram responsáveis pelos gols. O time da capital dominou o adversário — seu algoz da edição anterior do Estadual — e, apesar de dificuldade no início da partida, fez valer o maior nível técnico. O Tricolor vai enfrentar o Palmeiras na final do estadual. O duelo não decidia um Paulistão desde 1992 e a grande decisão em 2021 será no Morumbi.

Foi mais uma excelente atuação da equipe comandada por Crespo e, principalmente, do meia Benitez. O camisa 8 são-paulino foi o principal responsável pelas chances criadas da sua equipe. Mesmo com a vantagem no placar, os comandados de Crespo seguiram em cima, sem deixar de buscar o gol.

Agora o São Paulo volta suas forças para a Copa Libertadores. O próximo compromisso da equipe é contra o Racing-ARG, na terça (18), às 21h30, no Morumbi e a partida pode garantir a classificação da equipe para próxima fase.

INÍCIO TENSO

O Mirassol provou, logo no início, que poderia ser perigoso. Saindo nos contra-ataques, chegou a assustar o goleiro Volpi no começo da partida. Acontece que esse ímpeto não evoluiu e, aos poucos, o Tricolor foi tomando conta do jogo.

DOMÍNIO TRICOLOR

O São Paulo virou esse panorama a partir dos 10 minutos e ou a dar as cartas em campo. Encaixou melhor a marcação e começou a se impor diante do adversário. Apesar do volume de jogo, faltava criar chances claras de gol. O maior incômodo ao goleiro Muralha eram chutes de fora da área. Apenas Benítez, após cobrança de lateral, e Miranda completando um cruzamento, conseguiram finalizar de dentro de área.

ÁGUA MOLE EM PEDRA DURA...

O ditado se fez presente. Tanto lutou que logo conseguiu. O São Paulo abriu o placar após cobrança de escanteio de Benítez, no segundo pau. Muralha saiu mal do gol e o zagueiro Arboleda abriu o placar, no finalzinho do primeiro tempo. A liderança são-paulina fez jus ao melhor primeiro tempo e a equipe foi para o intervalo com vantagem.

SAI, ZICA!

Se no início do primeiro tempo, o Mirassol foi dono das ações, o São Paulo tratou de mudar esse cenário na etapa final. A marcação continuou agressiva e, logo aos quatro minutos, Pablo foi lançado no campo de ataque.

O atacante invadiu e área e tentou cavar na saída do goleiro, mas ia errando a finalização até que a bola encontrou Danilo Boza. Após o toque no zagueiro, a bola morreu no fundo das redes. E o São Paulo não queria mesmo dar espaço para o azar. Aos dez minutos, Benítez bateu escanteio, Miranda desviou no primeiro poste e Gabriel Sara, no segundo poste, completou para dentro do gol.

JOGO CONTROLADO

Com 3 a 0 no placar, coube ao São Paulo apenas controlar as ações do jogo. Crespo utilizou suas substituições para rodar o elenco e descansar os titulares. Eduardo Baptista também fez mudanças, buscando mais ofensividade da sua equipe, mirando ao menos um gol no Morumbi.

VOLTOU COM GOL

Luciano entrou em campo aos dezoito minutos na etapa complementar. Voltava após um período parado por lesão. Logo aos 11 minutos após a entrada, ele apareceu dentro da área para completar excelente jogada coletiva do São Paulo. O atacante completou cruzamento de Igor Vinícius e deu ainda mais tranquilidade para os donos da casa. Poucos minutos depois do gol, William marcou o seu, mas foi indicado o impedimento.

FICHA TÉCNICA

SÃO PAULO 4 X 0 MIRASSOL

Motivo: Semifinal do Campeonato Paulista;
Local: Estádio do Morumbi, em São Paulo (SP);
Data e horário: 16 de maio de 2021, às 20h30 (de Brasília);
Árbitro: Luiz Flávio de Oliveira;
Assistentes: Anderson José de Morais Coelho e Miguel Cataneo Ribeiro da Costa;
VAR: Márcio Henrique de Gois;
Cartão amarelo: Neto Moura e Daniel (MFC);
Gols: Arboleda, aos 44 do primeiro tempo; Pablo, aos 5 minutos, Gabriel Sara, aos 11 minutos, e Luciano, aos 29 minutos do segundo tempo;

SÃO PAULO: Volpi; Arboleda, Miranda, Léo; Igor Vinícius, Luan (William), Liziero (Rodrigo Nestor), Gabriel Sara (Igor Gomes), Reinaldo, Benitez (Rojas); Pablo (Luciano). Técnico: Hernán Crespo.

MIRASSOL: Alex Muralha; Daniel Borges, Danilo Boza, Renie, Ernandes; Sousa (Daniel), Neto Moura e Cássio Gabriel (Raphael Macena); Diego Gonçalves (Mateus Anderson), Fabrício (Lucas Souza) e Pedro Lucas. Técnico: Eduardo Baptista.

São Paulo