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 相关文章推荐
基于jquery实现的服务器验证控件的启用和禁用代码
Apr 27 Javascript
ASP.NET jQuery 实例6 (实现CheckBoxList成员全选或全取消)
Jan 13 Javascript
Chosen 基于jquery的选择框插件使用方法
May 30 Javascript
JavaScript实现x秒后自动跳转到一个页面
Jan 03 Javascript
jquery实现checkbox 全选/全不选的通用写法
Feb 22 Javascript
使用FlexiGrid实现Extjs表格效果方法分享
Dec 16 Javascript
谈谈impress.js初步理解
Sep 09 Javascript
jQuery基于$.ajax设置移动端click超时处理方法
May 14 Javascript
node文件上传功能简易实现代码
Jun 16 Javascript
JS 实现banner图片轮播效果(鼠标事件)
Aug 04 Javascript
JS事件循环机制event loop宏任务微任务原理解析
Aug 04 Javascript
JS继承实现方法及优缺点详解
Sep 02 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
967 个函式
2006/10/09 PHP
destoon实现底部添加你是第几位访问者的方法
2014/07/15 PHP
Smarty简单生成表单元素的方法示例
2016/05/23 PHP
Yii 2.0实现联表查询加搜索分页的方法示例
2017/08/02 PHP
Z-Blog中用到的js代码
2007/03/15 Javascript
初窥JQuery(二) 事件机制(1)
2010/11/25 Javascript
jquery插件制作简单示例说明
2012/02/03 Javascript
基于JQuery 滑动与动画的说明介绍
2013/04/18 Javascript
轻松创建nodejs服务器(7):阻塞操作的实现
2014/12/18 NodeJs
自定义jQuery插件方式实现强制对象重绘的方法
2015/03/23 Javascript
jQuery中text() val()和html()的区别实例详解
2016/06/28 Javascript
全面了解JS中的匿名函数
2016/06/29 Javascript
使用JavaScript获取Request中参数的值方法
2016/09/27 Javascript
微信开发 使用picker封装省市区三级联动模板
2016/10/28 Javascript
bootstrap表单按回车会自动刷新页面的解决办法
2017/03/08 Javascript
Angular2 自定义validators的实现方法
2017/07/05 Javascript
vue.js todolist实现代码
2017/10/29 Javascript
使用vue的transition完成滑动过渡的示例代码
2018/06/25 Javascript
小程序实现单选多选功能
2018/11/04 Javascript
vue的.vue文件是怎么run起来的(vue-loader)
2018/12/10 Javascript
微信小程序MUI侧滑导航菜单示例(Popup弹出式,左侧不动,右侧滑动)
2019/01/23 Javascript
微信sdk实现禁止微信分享(使用原生php实现)
2019/11/15 Javascript
Threejs实现滴滴官网首页地球动画功能
2020/07/13 Javascript
python encode和decode的妙用
2009/09/02 Python
Python+matplotlib实现华丽的文本框演示代码
2018/01/22 Python
Python对excel文档的操作方法详解
2018/12/10 Python
python 通过麦克风录音 生成wav文件的方法
2019/01/09 Python
Python实现简单查找最长子串功能示例
2019/02/26 Python
如何修复使用 Python ORM 工具 SQLAlchemy 时的常见陷阱
2019/11/19 Python
浅析Python数字类型和字符串类型的内置方法
2019/12/22 Python
python实现俄罗斯方块游戏(改进版)
2020/03/13 Python
解决Pycharm 中遇到Unresolved reference 'sklearn'的问题
2020/07/13 Python
新加坡时尚网上购物:Zalora新加坡
2016/07/26 全球购物
2015中学政教处工作总结
2015/07/22 职场文书
JavaScript中reduce()的用法
2022/05/11 Javascript
nginx静态资源的服务器配置方法
2022/07/07 Servers