Angular4如何自定义首屏的加载动画详解


Posted in Javascript onJuly 26, 2017

前言

相信大家都知道,在默认情况下,Angular应用程序在首次加载根组件时,会在浏览器的显示一个loading... 我们可以轻松地将loading修改成我们自己定义的动画。下面话不多说,来一起看看详细的介绍:

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

Angular4如何自定义首屏的加载动画详解

根组件标签中的内容

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

<!doctype html>
<html>
<head>
 <meta charset="utf-8">
 <title>Fancy Loading Screen</title>
 <base href="/" rel="external nofollow" >
 <meta name="viewport" content="width=device-width, initial-scale=1">
 <link rel="icon" type="image/x-icon" href="favicon.ico" rel="external nofollow" >
</head>
<body>

 <app-root>Loading...</app-root>

</body>
</html>

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

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

<app-root>
 <style>
 app-root {
  color: purple;
 }
 </style>
 I'm a purple loading message!
</app-root>

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

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

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

<app-root>
 <style>
 app-root {
 display: flex;
 justify-content: center;
 align-items: center;
 height: 100vh;

 color: pink;
 text-transform: uppercase;
 font-family: -apple-system,
  BlinkMacSystemFont,
  "Segoe UI",
  Roboto,
  Oxygen-Sans,
  Ubuntu,
  Cantarell,
  Helvetica,
  sans-serif;
 font-size: 2.5em;
 text-shadow: 2px 2px 10px rgba(0,0,0,0.2);
 }
 body {
 background: salmon;
 margin: 0;
 padding: 0;
 }

 @keyframes dots {
 50% {
  transform: translateY(-.4rem);
 }
 100% {
  transform: translateY(0);
 }
 }

 .d {
 animation: dots 1.5s ease-out infinite;
 }
 .d-2 {
 animation-delay: .5s;
 }
 .d-3 {
 animation-delay: 1s;
 }
 </style>

 Loading<span class="d">.</span><span class="d d-2">.</span><span class="d d-3">.</span>
</app-root>

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

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

  • loading.io
  • css-loaders
  • cssload

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

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
JavaScript的变量作用域深入理解
Oct 25 Javascript
33种Javascript 表格排序控件收集
Dec 03 Javascript
百度Popup.js弹出框进化版 拖拽小框架发布 兼容IE6/7/8,Firefox,Chrome
Apr 13 Javascript
根据选择不同的下拉值出现相对应的文本输入框
Aug 01 Javascript
jQuery中Ajax的load方法详解
Jan 14 Javascript
JavaScript前补零操作实例
Mar 11 Javascript
Jquery中的$.each获取各种返回类型数据的使用方法
May 03 Javascript
深入探究AngularJs之$scope对象(作用域)
Jul 20 Javascript
SelectPage v2.4 发布新增纯下拉列表和关闭分页功能
Sep 07 Javascript
在Vue组件中获取全局的点击事件方法
Sep 06 Javascript
使用Javascript简单计算器
Nov 17 Javascript
JS实现鼠标拖拽盒子移动及右键点击盒子消失效果示例
Jan 29 Javascript
vue上传图片组件编写代码
Jul 26 #Javascript
深入讲解xhr(XMLHttpRequest)/jsonp请求之abort
Jul 26 #Javascript
基于ExtJs在页面上window再调用Window的事件处理方法
Jul 26 #Javascript
Angular中自定义Debounce Click指令防止重复点击
Jul 26 #Javascript
JavaScript利用fetch实现异步请求的方法实例
Jul 26 #Javascript
深入探究angular2 UI组件之primeNG用法
Jul 26 #Javascript
WdatePicker.js时间日期插件的使用方法
Jul 26 #Javascript
You might like
phpmyadmin配置文件现在需要绝密的短密码(blowfish_secret)的2种解决方法
2014/05/07 PHP
深入分析PHP引用(&amp;)
2014/09/04 PHP
PHP实现手机号码中间四位用星号(*)隐藏的自定义函数分享
2014/09/27 PHP
laravel执行php artisan migrate报错的解决方法
2019/10/09 PHP
Jquery实现鼠标移上弹出提示框、移出消失思路及代码
2013/05/19 Javascript
多种方法判断Javascript对象是否存在
2013/09/22 Javascript
JS当前页面登录注册框,固定DIV,底层阴影的实例代码
2016/09/29 Javascript
Bootstrap导航条学习使用(一)
2017/02/08 Javascript
JavaScript 函数节流详解及方法总结
2017/02/09 Javascript
前端框架学习总结之Angular、React与Vue的比较详解
2017/03/14 Javascript
yii form 表单提交之前JS在提交按钮的验证方法
2017/03/15 Javascript
JQuery实现定时刷新功能代码
2017/05/09 jQuery
详解VUE 定义全局变量的几种实现方式
2017/06/01 Javascript
基于BootStrap实现简洁注册界面
2017/07/20 Javascript
JavaScript编写棋盘覆盖代码详解
2017/08/28 Javascript
利用JS实现scroll自定义滚动效果详解
2017/10/17 Javascript
详解为Bootstrap Modal添加拖拽的方法
2018/01/05 Javascript
vuejs实现递归树型菜单组件
2018/01/13 Javascript
angular 实现同步验证器跨字段验证的方法
2019/04/11 Javascript
jquery实现烟花效果(面向对象)
2020/03/10 jQuery
[02:50]2014DOTA2 TI预选赛预选赛 大神专访第一弹!
2014/05/21 DOTA
简单介绍利用TK在Python下进行GUI编程的教程
2015/04/13 Python
pymssql数据库操作MSSQL2005实例分析
2015/05/25 Python
Django实现图片文字同时提交的方法
2015/05/26 Python
Pycharm学习教程(6) Pycharm作为Vim编辑器使用
2017/05/03 Python
Python unittest 简单实现参数化的方法
2018/11/30 Python
Python Numpy库datetime类型的处理详解
2019/07/13 Python
python全局变量引用与修改过程解析
2020/01/07 Python
python实现将两个文件夹合并至另一个文件夹(制作数据集)
2020/04/03 Python
python产生模拟数据faker库的使用详解
2020/11/04 Python
班干部竞选演讲稿
2014/04/24 职场文书
学雷锋月活动总结
2014/04/25 职场文书
运动会演讲稿50字
2014/08/25 职场文书
北京导游词
2015/02/12 职场文书
开学第一周日记(三篇范文)
2019/08/23 职场文书
教你怎么用Python实现多路径迷宫
2021/04/29 Python