让Css3动画变得有趣WOWjs

wowjs可以在网页滚动时, 展示css动画,是animater的好朋友, wowjs官方实例演示链接: https://mynameismatthieu.com/WOW/


animate.css 包含了一组炫酷、有趣、跨浏览器的动画,可以在你的项目中直接使用。

使用方法

1. 在页面头部引入, animate.csswow.js, cdn地址如下:

<link href="https://cdn.bootcss.com/animate.css/3.5.2/animate.min.css" rel="stylesheet">
<script src="https://cdn.bootcss.com/wow/1.1.2/wow.min.js"></script>

2. 在需要添加动画的html元素上, 新增两个类属性, 第一个为wow, 第二个为动画名如从左侧滑入slideInLeft

从左边滑入的动画

3. 添加动画控制, 主要控制四个属性:

  • data-wow-duration: 动画持续时间
  • data-wow-delay: 动画开始之前的延迟播放的时间
  • data-wow-offset: 元素距离底部大于此数值时,开始播放动画
  • data-wow-iteration: 动画重复的次数
<!--动画持续时间为2秒, 动画开始之前的延迟播放的时间为5s 元素底部距离浏览器底部400像素时开始播放动画, 动画重复次数为2次-->
<p class="wow slideInLeft" data-wow-duration="2s" data-wow-delay="5s" data-wow-offset="400" data-wow-iteration="2">从左边滑入的动画</p>

4. 在html底部添加初始化语句

<script>
    wow = new WOW(
        {
            boxClass: 'wow',      // 默认属性名
            animateClass: 'animated', // 默认触发的动画类(包含在animate css中)
            offset: 0,          // 为所有添加wow的元素设置 data-wow-delay属性 的默认值
            mobile: true,       // 是否在移动设备中开启动画
            live: true        // 持续监测页面中是否插入新的wow元素
        }
    );
    wow.init();
</script>

小技巧: 在animater中大多数动画名都是"见名知意"的, 在这里可以在线查看: https://cdn.bootcss.com/animate.css/3.5.2/animate.css, 具体用法可以查看下面简单的小demo

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>wow动画</title>
    <link href="https://cdn.bootcss.com/animate.css/3.5.2/animate.min.css" rel="stylesheet">
    <script src="https://cdn.bootcss.com/wow/1.1.2/wow.min.js"></script>
</head>
<style>

    p {
        font-size: 50px;
        text-align: center;
        color:#64B587;
        line-height: 100px;
    }

    section {
        width: 800px;
        font-size: 30px;
        color: #A84631;
        text-align: center;
        line-height:60px;
        margin: 0 auto;
    }

    section div {

        height: 100px;
        line-height: 100px;
    }

</style>
<body>

<p class="wow slideInLeft">
    将进酒
</p>

<section >
    <div class="wow slideInLeft" data-wow-duration="2s" data-wow-delay="1s">
        君不见黄河之水天上来,奔流到海不复回。<br>
    </div>
    <div class="wow slideInLeft" data-wow-duration="3s" data-wow-delay="1s">
        君不见高堂明镜悲白发,朝如青丝暮成雪。<br>
    </div>
    <div class="wow bounceOutUp" data-wow-duration="2s" data-wow-delay="1s">
        人生得意须尽欢,莫使金樽空对月。<br>
    </div>
    <div class="wow fadeIn">
        天生我材必有用,千金散尽还复来。<br>
    </div>
    <div class="wow fadeInDown">
        烹羊宰牛且为乐,会须一饮三百杯。<br>
    </div>
    <div class="wow fadeInLeft">
        岑夫子,丹丘生,将进酒,杯莫停。<br>
    </div>
    <div class="wow fadeInLeftBig">
        与君歌一曲,请君为我倾耳听:<br>
    </div>
    <div class="wow fadeOutRightBig">
        钟鼓馔玉不足贵,但愿长醉不复醒。<br>
    </div>
    <div class="wow flipInX">
        古来圣贤皆寂寞,惟有饮者留其名。<br>
    </div>

    <div class="wow flipOutY">
        陈王昔时宴平乐,斗酒十千恣欢谑。<br>
    </div>
    <div class="wow lightSpeedIn">
        主人何为言少钱,径须沽取对君酌。<br>
    </div>
    <div class="wow rotateIn">
        五花马,千金裘,<br>
    </div>
    <div class="wow rotateInUpLeft">
        呼儿将出换美酒,与尔同销万古愁。<br>
    </div>
</section>
<!--动画持续时间为2秒, 动画开始之前的延迟播放的时间为5s 元素底部距离浏览器底部400像素时开始播放动画, 动画重复次数为2次-->
<p class="wow slideInLeft" data-wow-duration="2s" data-wow-delay="5s" data-wow-offset="400" data-wow-iteration="2">End</p>



</body>
<script>
    wow = new WOW(
        {
            boxClass: 'wow',      // 默认属性名
            animateClass: 'animated', // 默认触发的动画类(包含在animate css中)
            offset: 0,          // 为所有添加wow的元素设置 data-wow-delay属性 的默认值
            mobile: true,       // 是否在移动设备中开启动画
            live: true        // 持续监测页面中是否插入新的wow元素
        }
    );
    wow.init();
</script>
</html>

小结

animater可以增加网页的动感效果,动画的效果和ppt类似, 如果你肯花时间, 用animater做出好看的在线ppt效果也是完全可以做到的~

本文永久更新地址:

https://fangyuanxiaozhan.com/p/2020-01-25-18/

从「我的代码要改变世界」到「代码也不是最重要滴」

当初年轻不懂事,读了互联网之子,乔布斯传,以及林纳斯的传奇人生,就义无反顾地选了计算机专业。

大学专业课第一门编程语言不是C,也不是C++, 而是JAVA,对于大一新生而言。JAVA语法真的是啰嗦,如果不要求用JAVA写,我一定选择Python,毕竟程序员那么多,不缺我一个写JAVA的

大学毕业,从业两年后,深知编程不过是个普通技能,想做好一件事,最重要的是找对方向:

比如某L君找你要一个网页共享方案,大概有四种~

选项A:让他上传到云盘;
选项B:让他用git上传到仓库,然后打包发布;
选项C:让他ftp上传到网络空间;
选项D:给他开个Windows共享目录,然后自动挂载到局域网;

选项A很没水平,而且算不上http服务。
选项B得教会某L君使用git;
选项C得教会某L君使用ftp;
选项D只要L会拖拽文件就行。

我的工作就是直接给出D选项,而不是去教某L君使用ftp或git技术,或者给出传云盘这种很low的解决方案,给某L君一种就这我上我也行的错觉。

战争是最终的手段,战争是政治的延续,在政治中无法谋取的利益,才需要通过战争来获得。同理,代码是最终的手段,代码是工具库的延续,在已有工具库中找不到合适的工具时,才需要编写代码解决

当全世界都在开汽车的时候,有一个疯子执着地认为这个世界需要马车;如果我们不能拥有足够的时间(--摸鱼--)学习,我们就是别人眼中那个造马车的疯子(TNT出来后,讲一个IT界最短的笑话:罗永浩!)

万事不求人,说穿了,也是一种人格缺陷。小到一个开发组,大到一个公司,一个国家,个人的能力始终是有限的,如果能通过交流,减少工作量,那就主动去交流吧,交流产生的价值,远大于多写几行代码,世界上写代码的人多的是,不差你这几行

那些经常发出我要去写代码放我去写代码吧这类表情包的程序员,往好听了说,是坚信代码能解决一切问题的;往难听了说,就是人菜瘾还大;开发面临的问题千千万,程序归根到底只能解决一小部分数学题,用解数学题的解决所有问题,一定会加班。

怎样才能储备足够多的解决方案,遇到问题能整活儿呢?

作为一名IT从业者,github的每日trending榜一定要看

https://github.com/trending

另外,今日热榜是一个全网热门信息的集合页面,且实时更新,能帮我们快速搞到最新信息

https://tophub.today/

什么样的代码要写,什么样的代码不要写?

Github是个好地方,如果你能在github找到合适的代码,那就不要写;
如果你找遍全网都没有合适的解决方案或代码,那就写!
写代码一定多写注释,否则后期维护就是自己坑自己。

最后,以一个段子结束本篇文章,一个工程师应该有什么经验?
应具有丰富的挖坑,踩坑,爬坑,填坑以及躲锅,背锅经验!遇到问题不用慌,心中默念,常在河边走,哪有不湿鞋...

希望每个IT从业者,每天都为头发过于浓密而烦恼(手动狗头)!

本文永久更新地址:

https://fangyuanxiaozhan.com/p/2020-01-20-code/