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


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 相关文章推荐
Exjs 入门篇
Apr 07 Javascript
js实现仿百度瀑布流的方法
Feb 05 Javascript
浅谈JS运算符&&和|| 及其优先级
Aug 10 Javascript
微信小程序 picker 组件详解及简单实例
Jan 10 Javascript
如何编写一个完整的Angular4 FormText 组件
Nov 18 Javascript
js中document.write和document.writeln的区别
Mar 11 Javascript
vue解决弹出蒙层滑动穿透问题的方法
Sep 22 Javascript
vue实现条件判断动态绑定样式的方法
Sep 29 Javascript
js实现网页同时进行多个倒计时功能
Feb 25 Javascript
解决layui 表单元素radio不显示渲染的问题
Sep 04 Javascript
VUE DEMO之模拟登录个人中心页面之间数据传值实例
Oct 31 Javascript
el-table表头根据内容自适应完美解决表头错位和固定列错位
Jan 07 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 foreach 使用&(与运算符)引用赋值要注意的问题
2010/02/16 PHP
使用PHP遍历文件目录与清除目录中文件的实现详解
2013/06/24 PHP
PHP魔术方法以及关于独立实例与相连实例的全面讲解
2016/10/18 PHP
PHP下 Mongodb 连接远程数据库的实例代码
2017/08/30 PHP
PHP数组对象与Json转换操作实例分析
2019/10/22 PHP
今天是星期几的4种JS代码写法
2013/09/17 Javascript
Chrome扩展页面动态绑定JS事件提示错误
2014/02/11 Javascript
PHP中CURL的几个经典应用实例
2015/01/23 Javascript
深入理解JavaScript编程中的原型概念
2015/06/25 Javascript
javascript中Date format(js日期格式化)方法小结
2015/12/17 Javascript
wap手机端解决返回上一页的js实例
2016/12/08 Javascript
vuejs 单文件组件.vue 文件的使用
2017/07/28 Javascript
jQuery实现通过方向键控制div块上下左右移动的方法【测试可用】
2018/04/26 jQuery
Vue2.x中利用@font-size引入字体图标报错的解决方法
2018/09/28 Javascript
vue treeselect获取当前选中项的label实例
2020/08/31 Javascript
node使用async_hooks模块进行请求追踪
2021/01/28 Javascript
Python 网页解析HTMLParse的实例详解
2017/08/10 Python
Python socket套接字实现C/S模式远程命令执行功能案例
2018/07/06 Python
Python中对数组集进行按行打乱shuffle的方法
2018/11/08 Python
Python函数装饰器原理与用法详解
2019/08/16 Python
python实现的生成word文档功能示例
2019/08/23 Python
Python 线性回归分析以及评价指标详解
2020/04/02 Python
Selenium基于PIL实现拼接滚动截图
2020/04/10 Python
python读取hdfs上的parquet文件方式
2020/06/06 Python
如何使用python自带IDLE的几种方法
2020/10/10 Python
HTML5制作酷炫音频播放器插件图文教程
2014/12/30 HTML / CSS
CHRONEXT英国:您的首选奢华腕表目的地
2020/03/30 全球购物
介绍一下XMLHttpRequest对象
2012/02/12 面试题
中专生的个人自我评价
2013/12/11 职场文书
预备党员转正思想汇报
2014/01/12 职场文书
文明社区申报材料
2014/08/21 职场文书
新郎答谢词
2015/01/04 职场文书
团员自我评价范文
2015/03/10 职场文书
从np.random.normal()到正态分布的拟合操作
2021/06/02 Python
Python多个MP4合成视频的实现方法
2021/07/16 Python
字节飞书面试promise.all实现示例
2022/06/16 Javascript