自定义 Angular 4 首屏加载动画

前端之家收集整理的这篇文章主要介绍了自定义 Angular 4 首屏加载动画前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

默认情况下,Angular应用程序在首次加载根组件时,会在浏览器的显示一个loading... 我们可以轻松地将loading修改成我们自己定义的动画。

这是我们要实现首次加载的效果:

根组件标签中的内容

请注意,在你的入口文件index.html中,默认的loading...只是插入到根组件标签之间:

  1. <!doctype html>
  2. <html>
  3. <head>
  4. <Meta charset="utf-8">
  5. <title>Fancy Loading Screen</title>
  6. <base href="/">
  7. <Meta name="viewport" content="width=device-width,initial-scale=1">
  8. <link rel="icon" type="image/x-icon" href="favicon.ico">
  9. </head>
  10. <body>
  11.  
  12. <app-root>Loading...</app-root>
  13.  
  14. </body>
  15. </html>

如果您在加载完根组件检查应用程序,则无法找到loading...文字,因为它在应用加载完成后被我们自己定义的组件替换掉。

这意味着我们可以在这些标签之间放置任何内容包括样式定义,一旦Angular加载完根组件,就可以完全清除它们。

  1. <app-root>
  2. <style>
  3. app-root {
  4. color: purple;
  5. }
  6. </style>
  7. I'm a purple loading message!
  8. </app-root>

我们不必担心这些样式会影响我们的应用程序加载后的内容,因为一切都被完全替换掉。

现在你可以在那里随意的做任何事情。使用css或者svg实现自定义加载动画。

在我们的示例中,我们给页面一个粉红色的背景,我们使用FlexBox 将loading设置居中,给它设置一个更漂亮的字体,我们甚至在省略号上添加一个自定义动画:

  1. <app-root>
  2. <style>
  3. app-root {
  4. display: flex;
  5. justify-content: center;
  6. align-items: center;
  7. height: 100vh;
  8.  
  9. color: pink;
  10. text-transform: uppercase;
  11. font-family: -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen-Sans,Ubuntu,Cantarell,Helvetica,sans-serif;
  12. font-size: 2.5em;
  13. text-shadow: 2px 2px 10px rgba(0,0.2);
  14. }
  15. body {
  16. background: salmon;
  17. margin: 0;
  18. padding: 0;
  19. }
  20.  
  21. @keyframes dots {
  22. 50% {
  23. transform: translateY(-.4rem);
  24. }
  25. 100% {
  26. transform: translateY(0);
  27. }
  28. }
  29.  
  30. .d {
  31. animation: dots 1.5s ease-out infinite;
  32. }
  33. .d-2 {
  34. animation-delay: .5s;
  35. }
  36. .d-3 {
  37. animation-delay: 1s;
  38. }
  39. </style>
  40.  
  41. Loading<span class="d">.</span><span class="d d-2">.</span><span class="d d-3">.</span>
  42. </app-root>

这样我们就实现了上图的加载效果了,点击这里查看原文

分享几个loading效果的在线素材网:

好了,去创建属于你自己的loading吧!

猜你在找的Angularjs相关文章