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


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 相关文章推荐
使用原生JS实现弹出层特效
Dec 22 Javascript
创建js对象和js类的方法汇总
Dec 24 Javascript
基于jQuery实现的向下滑动二级菜单效果代码
Aug 31 Javascript
用户代理字符串userAgent可实现的四个识别
Sep 20 Javascript
jquery移除了live()、die(),新版事件绑定on()、off()的方法
Oct 26 Javascript
Bootstrap源码解读排版(1)
Dec 23 Javascript
轻松实现jQuery添加删除按钮Click事件
Mar 13 Javascript
详解Angular2表单-模板驱动的表单(Template-Driven Forms)
Aug 04 Javascript
JS中跳出循环的示例代码
Sep 14 Javascript
基于Vue制作组织架构树组件
Dec 06 Javascript
Vue请求JSON Server服务器数据的实现方法
Nov 02 Javascript
Vue实现滑动拼图验证码功能
Sep 15 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
15种PHP Encoder的比较
2007/04/17 PHP
PHPMyadmin 配置文件详解(配置)
2009/12/03 PHP
TMDPHP 模板引擎使用教程
2012/03/13 PHP
php实现通用的从数据库表读取数据到数组的函数实例
2015/03/21 PHP
ASP 过滤数组重复数据函数(加强版)
2010/05/31 Javascript
autoIMG 基于jquery的图片自适应插件代码
2011/03/12 Javascript
jquery加载页面的方法(页面加载完成就执行)
2011/06/21 Javascript
选择复选框按钮置灰否则按钮可用
2014/05/22 Javascript
教你用AngularJS框架一行JS代码实现控件验证效果
2014/06/23 Javascript
JavaScript 学习笔记之数据类型
2015/01/14 Javascript
JavaScript学习小结之被嫌弃的eval函数和with语句实例详解
2016/08/01 Javascript
JQuery学习总结【一】
2016/12/01 Javascript
javascript 删除数组元素和清空数组的简单方法
2017/02/24 Javascript
详解Angular的8个主要构造块
2017/06/20 Javascript
浅谈es6 javascript的map数据结构
2017/12/14 Javascript
jQuery实现鼠标响应式淘宝动画效果示例
2018/02/13 jQuery
jQuery中复合选择器简单用法示例
2018/03/31 jQuery
package.json各个属性说明详解
2020/03/11 Javascript
使用nodejs实现JSON文件自动转Excel的工具(推荐)
2020/06/24 NodeJs
Python多进程编程技术实例分析
2014/09/16 Python
matplotlib中legend位置调整解析
2017/12/19 Python
Python内置模块logging用法实例分析
2018/02/12 Python
python 读取文件并替换字段的实例
2018/07/12 Python
Django中自定义模型管理器(Manager)及方法
2019/09/23 Python
利用Tensorflow的队列多线程读取数据方式
2020/02/05 Python
python+selenium 简易地疫情信息自动打卡签到功能的实现代码
2020/08/22 Python
详解python tcp编程
2020/08/24 Python
python 基于opencv实现图像增强
2020/12/23 Python
使用canvas对多图片拼合并导出图片的方法
2018/08/28 HTML / CSS
“型”走纽约上东区:Sam Edelman
2017/04/02 全球购物
Linux开机引导的步骤是什么
2015/10/19 面试题
电子商务专业毕业生自荐书
2014/06/22 职场文书
装饰施工员岗位职责
2015/04/11 职场文书
2015社区六五普法工作总结
2015/04/21 职场文书
2015最新婚礼司仪主持词
2015/06/30 职场文书
《刷子李》教学反思
2016/02/20 职场文书