微信小程序实现自定义加载图标功能


Posted in Javascript onJuly 19, 2018

效果图

微信小程序实现自定义加载图标功能

实现思路

1.首先通过HTML+CSS实现加载动画的静态效果;

2.根据需求给每个动画设计不同的动画效果。

例如第一个加载图标的静态绘制

1、首先确定动画的盒子宽高;

2、设置盒子中每一个长方形的宽高以及定位(注意:此处需要将长方形的旋转中心点移动到长方形的右侧边终点,方便后期以该点旋转。);

3、通过长方形盒子的伪元素,设置显示的长方形背景和宽高,同时进行定位。

4、由于在第二步的时候,已经将旋转中心移动,此处我们直接对每一个盒子中长方形进行旋转(注意:旋转角度 = 360 / 盒子中长方形个数)。

.circle-line{
  width: 100px;
  height: 100px;
  display: inline-block;
  position: relative;
}
.circle-line text{
  display: block;
  width: 50%;
  height: 5px;
  opacity: .7;
  position: absolute;
  top: calc(50% - 2.5px);
  left: 0px;
  transform-origin: center right; 
}
.circle-line text::before{
  content: '';
  display: block;
  width: 15px;
  height: 5px;
  position: absolute;
  top: 0;
  right: 10px;
  background-color: blue;
}
.circle-line text:nth-child(1){
  transform: rotate(0deg);
}
.circle-line text:nth-child(2){
  transform: rotate(45deg);
}
.circle-line text:nth-child(3){
  transform: rotate(90deg);
}
.circle-line text:nth-child(4){
  transform: rotate(135deg);
}
.circle-line text:nth-child(5){
  transform: rotate(180deg);
}
.circle-line text:nth-child(6){
  transform: rotate(225deg);
}
.circle-line text:nth-child(7){
  transform: rotate(270deg);
}
.circle-line text:nth-child(8){
  transform: rotate(315deg);
}

动画制作

观察发现动画只是针对每个长方形的透明度进行改变,所以动画采用从0.05到0.9的透明度循环改变。

@keyframes circle {
  0%{
    opacity: 0.05;
  }
  100%{
    opacity: 0.9;
  }
}

进行动画绑定

.circle-line text{
  animation: circle 1.5s linear infinite; 
}

动画绑定完成,发现所有的整个图标一起显示消失,那么也就是缺少了对单个个体的动画处理,延迟动画时间,使其依次渐变。

单个动画处理

.circle-line text:nth-child(1){
  animation-delay: 0.2s;
}
.circle-line text:nth-child(2){
  animation-delay: 0.4s;
}
.circle-line text:nth-child(3){
  animation-delay: 0.6s;
}
.circle-line text:nth-child(4){
  animation-delay: 0.8s;
}
.circle-line text:nth-child(5){
  animation-delay: 1s;
}
.circle-line text:nth-child(6){
  animation-delay: 1.2s;
}
.circle-line text:nth-child(7){
  animation-delay: 1.4s;
}
.circle-line text:nth-child(8){
  animation-delay: 1.6s;
}

注意:单个动画延迟的时间必须超过动画执行的总时间,防止一个动画执行完成后的卡顿。

总结

以上所述是小编给大家介绍的微信小程序实现自定义加载图标功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JavaScript高级程序设计
Dec 29 Javascript
学习ExtJS Panel常用方法
Oct 07 Javascript
基于zepto.js实现仿手机QQ空间的大图查看组件ImageView.js详解
Mar 05 Javascript
jQuery实现简单倒计时功能的方法
Jul 04 Javascript
vue.js初学入门教程(1)
Nov 03 Javascript
JavaScript计时器用法分析【setTimeout和clearTimeout】
Jan 18 Javascript
Angularjs中使用轮播图指令swiper
May 30 Javascript
vue.js实现数据动态响应 Vue.set的简单应用
Jun 15 Javascript
JavaScript数据结构之优先队列与循环队列实例详解
Oct 27 Javascript
详解一个基于react+webpack的多页面应用配置
Jan 21 Javascript
node命令行工具之实现项目工程自动初始化的标准流程
Aug 12 Javascript
微信小程序如何通过用户授权获取手机号(getPhoneNumber)
Jan 21 Javascript
Angular5集成eventbus的示例代码
Jul 19 #Javascript
微信小程序实现弹出菜单
Jul 19 #Javascript
微信小程序实现之手势锁功能实例代码
Jul 19 #Javascript
React组件重构之嵌套+继承及高阶组件详解
Jul 19 #Javascript
微信小程序实现折叠展开效果
Jul 19 #Javascript
详解Angularjs 自定义指令中的数据绑定
Jul 19 #Javascript
微信小程序实现天气预报功能
Jul 18 #Javascript
You might like
php实现快速排序的三种方法分享
2014/03/12 PHP
php删除数组指定元素实现代码
2017/05/03 PHP
一个选择最快的服务器转向代码
2009/04/27 Javascript
jQuery EasyUI API 中文文档 - EasyLoader 加载器
2011/09/29 Javascript
js带缩略图的图片轮播效果代码分享
2015/09/14 Javascript
JS函数定义方式的区别介绍
2016/03/22 Javascript
Angularjs自定义指令实现三级联动 选择地理位置
2017/02/13 Javascript
Three.js利用性能插件stats实现性能监听的方法
2017/09/25 Javascript
Vue+jquery实现表格指定列的文字收缩的示例代码
2018/01/09 jQuery
vue 开发一个按钮组件的示例代码
2018/03/27 Javascript
详解Node.js amqplib 连接 Rabbit MQ最佳实践
2019/01/24 Javascript
Vue中的组件及路由使用实例代码详解
2019/05/22 Javascript
JavaScript静态作用域和动态作用域实例详解
2019/06/17 Javascript
微信小程序制作扭蛋机代码实例
2019/09/24 Javascript
JavaScript队列结构Queue实现过程解析
2020/03/07 Javascript
使用 Jest 和 Supertest 进行接口端点测试实例详解
2020/04/25 Javascript
python中bisect模块用法实例
2014/09/25 Python
日常整理python执行系统命令的常见方法(全)
2015/10/22 Python
pandas数据集的端到端处理
2019/02/18 Python
Python使用pyautocad+openpyxl处理cad文件示例
2019/07/11 Python
简单易懂Pytorch实战实例VGG深度网络
2019/08/27 Python
tensorflow 限制显存大小的实现
2020/02/03 Python
Python 实现 T00ls 自动签到脚本代码(邮件+钉钉通知)
2020/07/06 Python
python爬虫中url管理器去重操作实例
2020/11/30 Python
Python爬虫+tkinter界面实现历史天气查询的思路详解
2021/02/22 Python
红色连衣裙精品店:Red Dress Boutique
2018/08/11 全球购物
英国最大的在线时尚眼镜店:Eyewearbrands
2019/03/12 全球购物
介绍一下grep命令的使用
2012/06/28 面试题
投标邀请书范文
2014/01/31 职场文书
初中考试作弊检讨书
2014/02/01 职场文书
个人四风对照检查材料
2014/09/26 职场文书
2014年招生工作总结
2014/11/26 职场文书
大国崛起英国观后感
2015/06/02 职场文书
2015毕业设计工作总结
2015/07/24 职场文书
MySQL性能压力基准测试工具sysbench的使用简介
2021/04/21 MySQL
vue+elementUI实现表格列的显示与隐藏
2022/04/13 Vue.js