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


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 25 Javascript
一个页面元素appendchild追加到另一个页面元素的问题
Jan 27 Javascript
同域jQuery(跨)iframe操作DOM(实例讲解)
Dec 19 Javascript
用循环或if语句从json中取数据示例
Aug 18 Javascript
Node.js中HTTP模块与事件模块详解
Nov 14 Javascript
最精简的JavaScript实现鼠标拖动效果的方法
May 11 Javascript
JavaScript中将数组进行合并的基本方法讲解
Mar 07 Javascript
JSONP原理及简单实现
Jun 08 Javascript
JavaScript禁止用户多次提交的两种方法
Jul 24 Javascript
AngularJs分页插件使用详解
Jun 30 Javascript
Vue中保存数据到磁盘文件的方法
Sep 06 Javascript
微信小程序mpvue点击按钮获取button值的方法
May 29 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安全配置 如何配置使其更安全
2011/12/16 PHP
Win下如何安装PHP的APC拓展
2013/08/07 PHP
PHP生成条形图的方法
2014/12/10 PHP
64位windows系统下安装Memcache缓存
2015/12/06 PHP
PHP封装curl的调用接口及常用函数详解
2018/05/31 PHP
jQuery(非HTML5)可编辑表格实现代码
2012/12/11 Javascript
一个页面放2段图片滚动代码出现冲突的问题如何解决
2012/12/21 Javascript
如何从jQuery的ajax请求中删除X-Requested-With
2013/12/11 Javascript
js的参数有长度限制吗?发现不能超过2083个字符
2014/04/20 Javascript
使用AngularJS和PHP的Laravel实现单页评论的方法
2015/06/19 Javascript
AngularJS ng-bind-template 指令详解
2016/07/30 Javascript
一篇看懂vuejs的状态管理神器 vuex状态管理模式
2017/04/20 Javascript
vue将时间戳转换成自定义时间格式的方法
2018/03/02 Javascript
Vue.js中 v-model 指令的修饰符详解
2018/12/03 Javascript
详解Vue依赖收集引发的问题
2019/04/22 Javascript
基于Vue 撸一个指令实现拖拽功能
2019/10/09 Javascript
解决vue项目中页面调用数据 在数据加载完毕之前出现undefined问题
2019/11/14 Javascript
js实现无缝轮播图插件封装
2020/07/31 Javascript
token 机制和实现方式
2020/12/15 Javascript
vue使用lodop打印控件实现浏览器兼容打印的方法
2021/02/07 Vue.js
Flask-Mail用法实例分析
2018/07/21 Python
经验丰富程序员才知道的8种高级Python技巧
2020/07/27 Python
python如何调用百度识图api
2020/09/29 Python
css3 条纹化和透明化表格Firefox下测试成功
2014/04/15 HTML / CSS
使用CSS禁止textarea调整大小功能的方法
2015/03/13 HTML / CSS
UGG美国官网:购买UGG雪地靴、拖鞋和鞋子
2017/12/31 全球购物
skyn ICELAND官网:冰岛成分天然护肤品
2020/08/24 全球购物
Java里面有没有全局变量?为什么?
2015/02/06 面试题
总经理办公室主任岗位职责
2013/11/12 职场文书
学年自我鉴定
2014/01/16 职场文书
国培远程培训感言
2014/03/08 职场文书
微笑面对生活演讲稿
2014/05/13 职场文书
音乐兴趣小组活动总结
2014/07/07 职场文书
节能环保演讲稿
2014/08/28 职场文书
房屋分割离婚协议书范本
2014/12/01 职场文书
主持人开幕词
2015/01/29 职场文书