As transições CSS podem ser usadas para permitir que um parágrafo de texto desapareça no carregamento da página?
Eu realmente gosto da aparência em http://dotmailapp.com/ e adoraria usar um efeito semelhante usando CSS. O domínio já foi adquirido e não tem mais o efeito mencionado. Uma cópia arquivada pode ser visualizada na Wayback Machine .
Ilustração
Com esta marcação:
<div id="test">
<p>This is a test</p>
</div>
Com a seguinte regra CSS:
#test p {
opacity: 0;
margin-top: 25px;
font-size: 21px;
text-align: center;
-webkit-transition: opacity 2s ease-in;
-moz-transition: opacity 2s ease-in;
-o-transition: opacity 2s ease-in;
-ms-transition: opacity 2s ease-in;
transition: opacity 2s ease-in;
}
Como a transição pode ser acionada com carga?
css
css-transitions
opacity
user1556266
fonte
fonte
Respostas:
Método 1:
Se você estiver procurando por uma transição auto-invocadora, use CSS 3 Animations . Eles também não são suportados, mas é exatamente para isso que eles foram criados.
CSS
Demo
Suporte do navegador
Todos os navegadores modernos e Internet Explorer 10 (e posterior): http://caniuse.com/#feat=css-animation
Método 2:
Como alternativa, você pode usar o jQuery (ou JavaScript simples; consulte o terceiro bloco de código) para alterar a classe no carregamento:
jQuery
CSS
JavaScript simples (não na demo)
Demo
Suporte do navegador
Todos os navegadores modernos e Internet Explorer 10 (e posterior): http://caniuse.com/#feat=css-transitions
Método 3:
Ou, você pode usar o método que .Mail usa:
jQuery
CSS
Demo
Suporte do navegador
jQuery 1.x : todos os navegadores modernos e Internet Explorer 6 (e posterior): http://jquery.com/browser-support/
jQuery 2.x : todos os navegadores modernos e Internet Explorer 9 (e posterior): http: // jquery.com/browser-support/
Este método é o mais compatível entre si, pois o navegador de destino não precisa suportar transições ou animações CSS 3 .
fonte
opacity: 1 !important;
e coloquei um<noscript>
elemento.$("#test p").addClass("load");
várias vezes? Fazer$("#test p").removeClass('load').addClass("load");
não faz o trabalho, pois a animação já parou. Posso acionar uma reinicialização do JavaScript?Você pode usar o
onload=""
atributo HTML e JavaScript para ajustar o estilo de opacidade do seu elemento.Deixe o seu CSS como você propôs. Edite seu código HTML para:
Isso também funciona para desvanecer-se na página completa ao terminar o carregamento:
HTML:
CSS:
Verifique o site do W3Schools : transições e um artigo para alterar estilos com JavaScript .
fonte
<div id="test" onload="this.style.opacity='1'">
. Não tenho certeza se isso significa que o evento é disparado antes que o corpo inteiro seja carregado.Em resposta à pergunta da @ AMK sobre como fazer transições sem o jQuery. Um exemplo muito simples que joguei juntos. Se eu tiver tempo para pensar um pouco mais sobre isso, talvez eu consiga eliminar completamente o código JavaScript:
fonte