聊聊JS动画库 Velocity.js的使用


Posted in Javascript onMarch 13, 2018

前言

又到了炎热的7月,很久没有更新技术文章了,原因是上月月底实习结束,从公司离职。然后最近在弄自己的项目和考驾照,为了下次公司的应聘做准备,送别了女朋友到外地,哩哩啦啦半个月把一切事情都办妥后,还是静下心来学习新技术和写一写技术文章,希望能继续坚持下去吧。

JS动画

随着互联网越来越丰富多样,网页端的美化和新技术层出不穷,作为一个网站的浏览者,更多吸引他们的除了保证网站的流畅之外还有各种炫酷的交互动效。

网页的交互动效大概分为 css动画,js动画 。

JS动画的优点

既然我们大概了解了这两类动画,那么我们来分析下他们不同的优点

  1. css动画 由于css3可以根据css属性自定义动画 所以这类动画的优点就是不用进行计算和更改dom 会显得非常流畅。
  2. JS动画 js动画拥有强大的性能,并且优于css动画的特点就是 既然是根据js来改变属性值 所以没有css那样的局限性,可以实现更多的功能和动效,或许有人说js动画某些库会很慢,其实js动画本质很快,只是jquery让它慢了下来。因为有时候由于配合jquery使用,所以由于jquery本身的一些功能,所以在实现的时候就会显得很慢。

velocity.js 使用方法

JS动画的库非常多,各有各的有点,比如jquery自带的animate动画还有 webGL,或者利用canvas,SVG等实现其他效果,本次来讲的就是众多库中的其中一个 velocity.js 动画库。

velocity.js 既可以单独用JavaScript使用,也可以配合jquery使用,使用方法(注意先将velocity.js下载好后在body标签下引入,然后在新script标签中书写以下代码) :

//jquery方法 
var $div = $('div')
$div.velocity({属性:值,属性:值})
//javascript 方法
var oDiv = document.getElementById('div')
oDiv.velocity({属性:值,属性:值})

这里需要注意得几点:

1.里面的属性不能加引号写入,而后面的值如果有字符串则加引号,如果为整数则不用 比如 width:100 和 width:"100px"
2.里面的属性值不可一次传入多个,比如在css中 padding:5px 5px 6px 5px;我们可以这样传入 但是在velocity中如果想传入多个值则为 {paddingLeft:5, paddingRirght:5 省略}
3.里面的属性值 如果是多个转折的需要第二个首字母大写 如上

velocity.js 详细介绍

上面已经讲到 需要改变的值作为对象传入velocity的第一个参数,那么第二个参数就是 它的指定动画选项包含:

+ duration 持续时间
+ easing 缓动方式
+ delay 延迟执行
+ loop 循环次数
+ begin 和 complete 回调函数
+ display(值与css相同,可设置为auto)

在讲velocity指定动画选项前 我们先说一下velocity支持的值: px em rem % vm vh 或者 利用运算符 *=2 表示当前值的2倍 或者 /=2 等运算方式

下面一个一个分析下指定动画选项:

duration 持续时间

这个是代表动画的持续时间默认值为毫秒(ms) 你可以这样使用:

// 表示一秒内将透明度从1到0
$div.velocity({opacity:0},{duration:1000})

也可以这样使用:

// 效果相同
$div.velocity({opacity:0},1000)

velocity也自定了三种持续方式:slow(600ms) ,normal(400ms),fast(200ms),可根据自己实际需求使用

easing 缓动方式

这个是代表着动画以何种方式进行变换:ease-in-out(逐加逐减),ease-in (先加速后匀速),dase-out (先匀速后减速)

也可以根据 三角函数缓动 "easeInOutSine" ,css贝塞尔曲线[0.17,0.67,0.83,0.67] 或者弹簧物理 [张力,摩擦力] 等值进行实现

delay 延迟执行

表示这个动画延迟多少时间执行 默认单位毫秒(ms)

// 五秒后执行此动画
delay:5000

loop 循环次数

表示这个动画需要的循环次数:

// 循环五次
loop:5
// 无限循环
loop:true

begin和complete回调函数

这两个表示在动画开始前和动画结束后所执行的函数:

begin:function(){ somgthing... },complete:function(){ somgthing... }

其他功能:

velocity还有一些其他功能,这里就日后再说,比如:reverse(反转),scrolling(滚动),color(颜色),transform(变换 包含scale缩放 rotate旋转 translation平移等)

结语

总之前端技术现在层出不穷,作为程序员的我们更应学习一些新的技术,既然热爱,就永无止境,以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
为JavaScript提供睡眠功能(sleep) 自编译JS引擎
Aug 16 Javascript
学习js在线html(富文本,所见即所得)编辑器
Dec 18 Javascript
jquery入门——事件机制之事件中的冒泡现象示例解释
Sep 12 Javascript
浅谈$(document)和$(window)的区别
Jul 15 Javascript
浅谈JavaScript中指针和地址
Jul 26 Javascript
第一次接触JS require.js模块化工具
Apr 17 Javascript
switch语句的妙用(必看篇)
Oct 03 Javascript
jQuery自定义组件(导入组件)
Nov 08 Javascript
bootstrap的3级菜单样式,支持母版页保留打开状态实现方法
Nov 10 Javascript
深入浅析AngularJs模版与v-bind
Jul 06 Javascript
浅谈Vue.js 中的 v-on 事件指令的使用
Nov 25 Javascript
javascript的setTimeout()使用方法总结
Nov 20 Javascript
vue toggle做一个点击切换class(实例讲解)
Mar 13 #Javascript
Vue2.0 给Tab标签页和页面切换过渡添加样式的方法
Mar 13 #Javascript
vue2.0 实现页面导航提示引导的方法
Mar 13 #Javascript
vue2.0 根据状态值进行样式的改变展示方法
Mar 13 #Javascript
使用Vuex实现一个笔记应用的方法
Mar 13 #Javascript
基于Axios 常用的请求方法别名(详解)
Mar 13 #Javascript
Bootstrap 中data-[*] 属性的整理
Mar 13 #Javascript
You might like
yii框架结合charjs实现统计30天数据的方法
2020/04/04 PHP
JavaScript 监听textarea中按键事件
2009/10/08 Javascript
5款Javascript颜色选择器
2009/10/25 Javascript
jQuery Jcrop插件实现图片选取功能
2011/11/23 Javascript
js动态创建标签示例代码
2014/06/09 Javascript
JS使用parseInt解析数字实现求和的方法
2015/08/05 Javascript
轻松学习jQuery插件EasyUI EasyUI创建树形菜单
2015/11/30 Javascript
详解javascript实现自定义事件
2016/01/19 Javascript
学习JavaScript设计模式之模板方法模式
2016/01/20 Javascript
使用基于Node.js的构建工具Grunt来发布ASP.NET MVC项目
2016/02/15 Javascript
AngularJs bootstrap搭载前台框架——基础页面
2016/09/01 Javascript
javascript 中事件冒泡和事件捕获机制的详解
2017/09/01 Javascript
浏览器调试动态js脚本的方法(图解)
2018/01/19 Javascript
使用webpack-dev-server处理跨域请求的方法
2018/04/18 Javascript
简单了解JavaScript中的执行上下文和堆栈
2019/06/24 Javascript
python 将字符串转换成字典dict
2013/03/24 Python
Python中函数eval和ast.literal_eval的区别详解
2017/08/10 Python
python绘制铅球的运行轨迹代码分享
2017/11/14 Python
Python面向对象程序设计之继承与多继承用法分析
2018/07/13 Python
Python2和Python3之间的str处理方式导致乱码的讲解
2019/01/03 Python
对Python 获取类的成员变量及临时变量的方法详解
2019/01/22 Python
pyqt 实现为长内容添加滑轮 scrollArea
2019/06/19 Python
Python项目 基于Scapy实现SYN泛洪攻击的方法
2019/07/23 Python
Python容器使用的5个技巧和2个误区总结
2019/09/26 Python
python set集合使用方法解析
2019/11/05 Python
windows10 pycharm下安装pyltp库和加载模型实现语义角色标注的示例代码
2020/05/07 Python
浅谈tensorflow中dataset.shuffle和dataset.batch dataset.repeat注意点
2020/06/08 Python
python爬取微博评论的实例讲解
2021/01/15 Python
HTML5通过navigator.mediaDevices.getUserMedia调用手机摄像头问题
2020/04/27 HTML / CSS
利用Node实现HTML5离线存储的方法
2020/10/16 HTML / CSS
学生会竞选自荐信
2013/10/12 职场文书
新手上路标语
2014/06/20 职场文书
员工培训协议书
2014/09/15 职场文书
初中教师德育工作总结2015
2015/05/12 职场文书
2016基督教会圣诞节开幕词
2016/03/04 职场文书
详解MySQL多版本并发控制机制(MVCC)源码
2021/06/23 MySQL