如何使用less实现随机下雪动画详解


Posted in Javascript onJanuary 02, 2019

前言

元旦在公司撸码,想起圣诞节的摇摇乐项目有段代码挺有意思的,借着空闲的时间把代码抽出来,沉淀下经验。

冬天来了,设计师说摇摇乐的场景需要随机下落的雪花动画,第一时间就想到的方法是canvas比较好,项目非常紧急,然而小程序对canvas支持不够友好,容易在项目中出现无法预估的兼容性问题 ,马上又否定了这种想法,想了想用javascript来写随机动画成本又高。既不用canvas也不用javascript来实现,最终决定使用css预处理器less来实现随机雪花,less怎么可能实现随机雪花?对于喜欢写css的人来说,这非常有趣。

如何使用less实现随机下雪动画详解

上图的雪花效果还蛮炫酷吧,怎么实现呢?less因为有以下的2个特点,可以尝试使用它来实现我们的场景

1.递归调用

实际上less并没有自带类似javascript的for循环的功能,但less可以用过引导when来实现条件判断,简单的方法也可以让聪明的程序员简单实现递归调用

.snow(@n) when (@n > 0) {

 fn()//生成雪花函数fn()

 .snow((@n - 1));//再次执行函数fn()

}
.snow(60);//执行次数

2.避免编译JavaScript 表达式

雪花需要生成的随机数,我们需要运用javascript表达式嵌入到less代码,同时也要避免javascript表达式被less错误的编译,我们需要了解两个点。

  • 一些 LESS不认识的专有语法,可以在字符串前加上一个 ~,
  • JavaScript 表达式在less 文件中使用,可以通过反引号的方式使用

于是有了如下随机位移、随机时间、随机大小的代码

left: ~"`Math.round(Math.random() * @{windowWidth})`px";
animation: ~"snowani_@{n} `(-Math.random() * 4 + 8).toFixed(2)`s linear infinite";
transform: ~"scale(`(Math.random() * 0.7 + 0.5).toFixed(2)`)";

于是有了如下的Less代码,具体怎么实现请留意详细的代码注释

以下less代码使用构建后可生产一份随机css固定雪花文件,决定了每一个雪花有不同的大小、水平位移、垂直位移、出场位置、出场时间,不同的雪花大小,不同的下落速度,用肉眼看到的雪花就像是随机的,可以在项目上线前尝试多构建几次,得到一份均匀分布在窗口的随机雪花。

* {
 padding: 0;
 margin: 0;
}
html, body {
 height: 100%;
}

//浏览器窗口宽度
@windowWidth: 750;
//雪花
.snow {
 &_wrap{
 position: relative;
 width: ~"@{windowWidth}px";
 height: 100%;
 overflow: hidden;
 background: rgba(14,99,69,1);
 margin: 0 auto;
 }
 //雪花初始化大小
 position: absolute;
 width:20px;
 height: 20px;
 &:after{
 content: '';
 position: absolute;
 left:0;
 top:0;
 width:20px;
 height: 20px;
 background-color:#fff;
 opacity:1;
 border-radius: 100%;
 filter:blur(5px);//此处使用css3滤镜来画雪花
 }
}
//随机雪花函数
.snow(@n) when (@n > 0) {
 .snow_@{n}{
 //水平方向上的位移
 left: ~"`Math.round(Math.random() * @{windowWidth})`px";
 //动画运行时间8~12秒,保证雪花有不同的移动速度
 animation: ~"snowani_@{n} `(-Math.random() * 4 + 8).toFixed(2)`s linear infinite";
 //动画提前出场时间,也就是垂直方向上位移
 animation-delay: ~"`(-Math.random() * 8 + 0.2).toFixed(2)`s";
 &:after{
  //雪花大小随机,0.5~1.2
  transform: ~"scale(`(Math.random() * 0.7 + 0.5).toFixed(2)`)";
 }
 }
 @keyframes ~"snowani_@{n}" {
 0%{
  transform: translateY(0);
 }
 100%{
  //垂直方向上高度,保证雪花有不同的移动速度
  transform: ~"translateY(`Math.round(Math.random() * 200 + 1600)`px)";
 }
 }
 .snow((@n - 1));
}
.snow(60);//生成雪花的数量

把上面的雪花的代码构建后如下:

如何使用less实现随机下雪动画详解

还有HTML,一行代码的事情

在编辑器中安装好emmet或webstorm开启emmet后,输入下面代码按下ctrl+e快捷键即可生成60个不同命名的雪花标签。

.snow_wrap>.snow.snow_$*60

如何使用less实现随机下雪动画详解

软件开发没有银弹,不要让经验固化了我们的思维,相信还有更多更好的实现方式,来提升我们的开发效率。

新年第一弹,新的开始,猪大家元旦快乐,抽中摇摇乐免单,身体健康,大吉大利。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
javascript onmouseout 解决办法
Jul 17 Javascript
js的.innerHTML = ""IE9下显示有错误的解决方法
Sep 16 Javascript
基于JavaScript Array数组方法(新手必看篇)
Aug 20 Javascript
微信开发 js实现tabs选项卡效果
Oct 28 Javascript
利用JQuery阻止事件冒泡
Dec 01 Javascript
Three.js基础部分学习
Jan 08 Javascript
JavaScript 数据类型详解
Mar 13 Javascript
关于bootstrap日期转化,bootstrap-editable的简单使用,bootstrap-fileinput的使用详解
May 12 Javascript
vue之数据交互实例代码
Jun 20 Javascript
JS计算输出100元钱买100只鸡问题的解决方法
Jan 04 Javascript
「中高级前端面试」JavaScript手写代码无敌秘籍(推荐)
Apr 08 Javascript
JS表单验证插件之数据与逻辑分离操作实例分析【策略模式】
May 01 Javascript
详解Vue2 添加对scss的支持
Jan 02 #Javascript
详解@Vue/Cli 3 Invalid Host header 错误解决办法
Jan 02 #Javascript
JS中数据结构之栈
Jan 01 #Javascript
微信小程序自定义导航栏
Dec 31 #Javascript
JavaScript ES6中的简写语法总结与使用技巧
Dec 30 #Javascript
JavaScript ES6箭头函数使用指南
Dec 30 #Javascript
JavaScript创建防篡改对象的方法分析
Dec 30 #Javascript
You might like
header()函数使用说明
2006/11/23 PHP
PHP 分页类(模仿google)-面试题目解答
2009/09/13 PHP
非常精妙的PHP递归调用与静态变量使用
2012/12/16 PHP
深入分析PHP优化及注意事项
2016/07/04 PHP
php curl优化下载微信头像的方法总结
2018/09/07 PHP
javascript while语句和do while语句的区别分析
2007/12/08 Javascript
基于jquery的高性能td和input切换并可修改内容实现代码
2011/01/09 Javascript
javascript分页代码(当前页码居中)
2012/09/20 Javascript
jQuery中;function($,undefined) 前面的分号的用处
2014/12/17 Javascript
javascript实用方法总结
2015/02/06 Javascript
jQuery+html5实现div弹出层并遮罩背景
2015/04/15 Javascript
javascript html5摇一摇功能的实现
2016/04/19 Javascript
JS实现添加,替换,删除节点元素的方法
2016/06/30 Javascript
Bootstrap风格的zTree右键菜单
2017/02/17 Javascript
javascript获取图片的top N主色值方法详解
2018/01/26 Javascript
Servlet返回的数据js解析2种方法
2019/12/12 Javascript
Flexible.js可伸缩布局实现方法详解
2020/11/13 Javascript
three.js如何实现3D动态文字效果
2021/03/03 Javascript
[02:34]肉山说——泡妞篇
2014/09/16 DOTA
从Python的源码浅要剖析Python的内存管理
2015/04/16 Python
Python中json格式数据的编码与解码方法详解
2016/07/01 Python
python opencv 二值化 计算白色像素点的实例
2019/07/03 Python
Django Rest framework认证组件详细用法
2019/07/25 Python
pygame实现俄罗斯方块游戏(基础篇1)
2019/10/29 Python
python实现logistic分类算法代码
2020/02/28 Python
python变量的作用域是什么
2020/05/26 Python
python 绘制正态曲线的示例
2020/09/24 Python
英国最大的割草机购买网站:Just Lawnmowers
2019/11/02 全球购物
电脑教师的自我评价
2013/12/18 职场文书
乔迁宴答谢词
2014/01/21 职场文书
求职信怎么写
2014/05/23 职场文书
高中教师先进事迹材料
2014/08/22 职场文书
2014领导班子四风问题查摆思想汇报
2014/09/13 职场文书
家属答谢词
2015/01/05 职场文书
比较几种Redis集群方案
2021/06/21 Redis
使用CSS设置滚动条样式
2022/01/18 HTML / CSS