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

Suflês doces e salgados: 7 receitas para você surpreender na cozinha

Suflê de queijo - Getty Imates/iStockphoto
Suflê de queijo Imagem: Getty Imates/iStockphoto

De Nossa

18/09/2020 11h36

De origem sa, soufflé significa 'assoprado', palavra que se relaciona com uma das principais características do prato: a leveza.

Para chegar à textura perfeita, o segredo está na incorporação de ar à mistura. E quem faz esse papel de dar uma estrutura firme, com volume e delicadeza ao mesmo tempo, é a clara de neve.

Suflê cai super bem como sobremesa - Getty Images - Getty Images
Suflê: também cai super bem como sobremesa
Imagem: Getty Images

O restante dos ingredientes pode variar de acordo com o sabor, que pode ser doce, como goiabada e chocolate, ou salgado, caso dos de queijos e vegetais.

Servido no ramequim, o preparo tem uma elegância ímpar e fica mais apetitoso ainda quando é deixado no forno até dourar.

Escolha sua receita favorita entre as sete listadas abaixo e mão na massa!

Para começar

Oferecidos como entrada ou prato principal, os suflês salgados costumam valorizar ingredientes como queijos e legumes. Para ganhar mais sabor, podem levar temperos como pimenta-do-reino e noz-moscada. Confira três opções:

Suflê de Espinafre com Gruyère

4 porções
60 min
Ver receita completa

Suflê de cenoura

3 porções
Ver receita completa

Suflê de Espinafre

4 porções
30 min
Ver receita completa

Doces

Os suflês são servidos como sobremesa logo que saem do forno. Versáteis, podem ser feitos de chocolate, de goiabada ou ainda levar alguma calda para incrementar, caso do creme de café. Outro acompanhamento que vai bem para esse tipo de receita é o sorvete. Olha, é difícil alguém resistir a uma colherada!

Suflê Romeu e Julieta

Dificuldade Fácil
8 porções
25 min
Ver receita completa

Suflê de chocolate

Dificuldade Médio
2 porções
Ver receita completa

Suflê de Goiabada com Catupiry

4 porções
Ver receita completa

Suflê de Chocolate com Creme de Café

4 porções
60 min
Ver receita completa