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


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 相关文章推荐
Jquery Ajax学习实例7 Ajax所有过程事件分析示例
Mar 23 Javascript
DIV外区域Click后关闭DIV的实现代码
Dec 21 Javascript
jquery.pagination.js 无刷新分页实现步骤分享
May 23 Javascript
使用jQuery判断IE浏览器版本的代码
Jun 14 Javascript
node.js中的buffer.Buffer.isBuffer方法使用说明
Dec 14 Javascript
JavaScript中Boolean对象的属性解析
Oct 21 Javascript
三种带箭头提示框总结实例
Jun 14 Javascript
JavaScript基本类型值-Undefined、Null、Boolean
Feb 23 Javascript
微信小程序 swiper组件构建轮播图的实例
Sep 20 Javascript
jQuery中each方法的使用详解
Mar 18 jQuery
微信小程序日历弹窗选择器代码实例
May 09 Javascript
vue项目出现页面空白的解决方案
Oct 31 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以post形式发送xml的方法
2014/11/04 PHP
PHP面向对象程序设计(OOP)之方法重写(override)操作示例
2018/12/21 PHP
浅析PHP7 的垃圾回收机制
2019/09/06 PHP
JavaScript实现禁止后退的方法
2006/12/27 Javascript
input 输入框内的输入事件详细分析
2010/03/17 Javascript
JQuery 应用 JQuery.groupTable.js
2010/12/15 Javascript
jQuery点击tr实现checkbox选中的方法
2013/03/19 Javascript
JQuery在页面中添加和除移DOM示例代码
2013/06/24 Javascript
nodejs分页类代码分享
2014/06/17 NodeJs
javascript比较两个日期的先后示例代码
2014/12/31 Javascript
js的toUpperCase方法用法实例
2015/01/27 Javascript
微信小程序 wx.request(接口调用方式)详解及实例
2016/11/23 Javascript
浅谈jQuery this和$(this)的区别及获取$(this)子元素对象的方法
2016/11/29 Javascript
超全面的JavaScript开发规范(推荐)
2017/01/21 Javascript
Node.js 8 中的重要新特性
2017/06/28 Javascript
JS实现去除数组中重复json的方法示例
2017/12/21 Javascript
Vue中v-show添加表达式的问题(判断是否显示)
2018/03/26 Javascript
React学习之JSX与react事件实例分析
2020/01/06 Javascript
一个简单的python程序实例(通讯录)
2013/11/29 Python
Python中实现远程调用(RPC、RMI)简单例子
2014/04/28 Python
python函数形参用法实例分析
2015/08/04 Python
TensorFlow实现随机训练和批量训练的方法
2018/04/28 Python
python3利用venv配置虚拟环境及过程中的小问题小结
2018/08/01 Python
对PyQt5的输入对话框使用(QInputDialog)详解
2019/06/25 Python
Python二次规划和线性规划使用实例
2019/12/09 Python
Python numpy矩阵处理运算工具用法汇总
2020/07/13 Python
Python+unittest+requests 接口自动化测试框架搭建教程
2020/10/09 Python
新加坡最佳婴儿用品店:Mamahood.com.sg
2018/08/26 全球购物
《老王》教学反思
2014/02/23 职场文书
百日安全活动总结
2014/05/04 职场文书
大学生求职信例文
2014/06/29 职场文书
琅琊山导游词
2015/02/05 职场文书
生活小常识广播稿
2015/08/19 职场文书
小学四年级班务总结该怎么写?
2019/08/16 职场文书
MySQL 用 limit 为什么会影响性能
2021/09/15 MySQL
MySQL创建定时任务
2022/01/22 MySQL