一、事件绑定

1.鼠标事件:模拟触发

什么是模拟触发?

虽然没有点在按钮上,也可以触发按钮的事件处理函数。

如何:$元素.trigger("事件名")

即使没有点在指定的元素上,也能触发该元素上绑定的事件处理函数。

简写:如果要触发的事件,刚好是21种简写中的一种,可使用事件处理函数一个函数两用的方法触发:

$元素.事件名()

强调:()中不要加处理函数

二、动画

简单动画:写死的固定不变的三种动画效果:

1.显示隐藏:.show()、.hide()、.toggle()

问题:.show() 、.hide()不加参数时,默认使用display:block和display:none控制瞬间显示隐藏。

如果想有动画效果,必须加持续事件参数。

2.上滑下滑: .slideUp()、.slideDown()、.slideToggle()

3.淡入淡出:.fadeIn()、.fadeOut()、.fadeToggle()

简单动画所有函数的共性问题:

1.效果是写死的!几乎不可维护!

2.用js定时器和DOM操作模拟的动画效果-----效率极低

但是,.show()、.hide()、.toggle()在不加参数时,代替的是.css("display","block/none"),

这个是没有效率和可维护性损失的。所以,这三个不加参数的情况,还是非常推荐使用的。

2.万能动画:

什么是:可对任意css属性应用动画效果

何时:只要希望对任意css属性应用动画效果时

如何:

1.$元素.animate({ css属性:目标值 } [动画持续时间,callback])

2.让当前元素从现在的状态,经过指定的时间后,缓慢过渡到目标状态。

3.强调:animate()中只需要些目标值,animate()可自动获得当前的对应属性值,自动计算变化的距离。

问题:

1.也是用js定时器和DOM操作模拟的动画效果

2.其实只支持单个数值的css属性,不支持CSS3动画,不支持颜色过渡。

排队和并发:

1.并发执行:多个css属性同时变化

如何:一个animate()内的多个css属性默认并发执行。

2.排队并发:多个css属性按顺序依次先后变化

如何:对同一个元素先后调用多次animate()函数,多次animate函数中的css属性是排队执行。

原理:其实在jq中,每个元素都有一个动画队列。

调用animate时,其实并不是立刻播放动画的意思,仅仅是将动画加入队列中保存

能否立刻执行动画,取决于当前动画之前是否有等待的或正在执行的其他动画。

在动画结束后自动执行:

问题:jq的动画函数都是用js定时器模拟的,所以都是异步的!

解决:每个动画函数都提供了最后一个参数,是一个回调函数。写在这个回调函数中的代码,

都是在动画结束后,才自动调用的。

停止动画:$元素.stop()

坑:默认只能停止当前正在播放的一个动画。如果队列中后续还有其他动画,则依然继续执行。

解决:$元素.stop(true)                 停止当前动画,且清除动画队列。

判断一个元素是否在播放jquery动画:

1.:animated 选择器

2.专门匹配正在播放动画的元素

4.类数组对象操作:

js中类数组对象很受歧视,长得像数组,但数组家的好用的函数,类数组对象都用不了。

但是,jq中创建的jq对象,都是类数组对象,于是,JQuery就为jq对象,模拟出了两个和数组家功能相似的函数:

1.遍历:

js数组中:arr.forEach(function(elem,i,arr){....})

jq中:$(查找结果).each(function(i,DOM元素){....})

依次取出.前的查找结果集合中的每个DOM元素,执行相同的操作!

2.查找:js数组中:var i =arr.indexOf(值)

js中:var i=$(查找结果).index(元素)              查找元素在结果集合中的位置i

Jquery动画,排队与并发的更多相关文章

  1. 深入学习jQuery动画控制

    × 目录 [1]动画状态 [2]停止动画 [3]动画延迟[4]全局控制 前面的话 jQuery动画可以使用fade.hide.slide等方法实现基本动画效果,可以使用animate实现自定义动画,甚 ...

  2. 让网站动起来!12款优秀的 jQuery 动画插件推荐

    如今,大多数设计师和开发人员被要客户要求开发动态的网站.创造视觉震撼和醒目的动态网站是艰巨的任务,因为它需要大量的努力和创造力.在网络上有大量的工具和插件可用于创建网站动画.许多开发人员正在使用 HT ...

  3. jquery 动画总结(主要指效果函数)

    动画无非两类:帧动画frame和变形动画tween,以及3d动画.不论web还是安卓苹果app,动画原理都是这些. web app 动画实现的途径,无非这几种:1 gif动画---这就是帧动画,把若干 ...

  4. js进阶 13 jquery动画函数有哪些

    js进阶 13 jquery动画函数有哪些 一.总结 一句话总结: 二.jquery动画函数有哪些 原生JavaScript编写动画效果代码比较复杂,而且还需要考虑兼容性.通过jQuery,我们使用简 ...

  5. js进阶 13-6 jquery动画效果相关常用函数有哪些

    js进阶 13-6 jquery动画效果相关常用函数有哪些 一.总结 一句话总结:animate(),stop(),finish(),delat()四个. 1.stop()方法的基本用法是什么(sto ...

  6. 让网站动起来!12款优秀的 jQuery 动画

    Textillate.js 介绍:Textillate.js 是一个简单的 CSS3 文本动画插件.结合了一些非常棒的库,把 CSS3 动画轻松应用到任何文本.只需要在项目中简单地引入 textill ...

  7. jQuery动画的实现

    没有引入deferred机制,其余流程都有了 //////////// //创建动画缓动对象 // //////////// function Tween(value, prop, animation ...

  8. 深入学习jQuery动画队列

    前面的话 队列实现是jQuery非常棒的一个拓展,使用动画队列可以使动画更容易实现.本文将详细介绍jQuery动画队列 queue() queue()方法用来显示在匹配的元素上的已经执行的函数队列 q ...

  9. jquery动画,基础以及我发现的新大陆

    $.animate()在jquery官方介绍有2中方式,其实我发现的新大陆也是第二种方式的扩展! 一.$.animate( properties [, duration ] [, easing ] [ ...

随机推荐

  1. php里的闭包函数

    一个匿名函数内要获取外部的变量必须要使用use: $message = 'hello'; $example = function() use ($message){ var_dump($message ...

  2. 双链表【参照redis链表结构】

    参照了Redis里面的双链表结构,可以说是完全复制粘贴,redis的双链表还是写的很通俗易懂的,没有什么花里胡哨的东西,但是redis还有个iter迭代器的结构来遍历链表.我这里就没有实现了,只是实现 ...

  3. 计算2的n次幂htm代码

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. swift 3.0字符串的简单使用

    let str:String = "12314124" 获取某个指定位置的元素 print(str.characters[str.index(str.startIndex, off ...

  5. Angular 7开发环境配置

    目录 前言 一.搭建项目  1.安装Angular CLI  2.创建项目  3.集成Element Angular 二.设置路由  1.创建路由模块  2.导入.导出RouterModule类  3 ...

  6. MySQL用另一张表的字段值Update本表

    SQL示例: UPDATE TABLE1 a, TABLE2 b SET a.field1 = b. field1 [, a.field2 = b.field2, ...] WHERE a.connn ...

  7. CentOS+Subversion 配置Linux 下 SVN服务器

    1.安装#yum install subversion测试安装是否成功:#svnserve –version     回车显示版本说明安装成功 2.配置 ·建立版本库 #mkdir /opt/svnd ...

  8. python 多进程处理 multiprocessing模块

    前提: 有时候一个用一个进程处理一个列表中的每个元素(每个元素要传递到一个函数中进行处理),这个时候就要用多进程处理 1 现场案例: 我有一个[ip1,ip2,ip3,.......]这样的列表,我要 ...

  9. Codeforces Round #561 (Div. 2) A. Silent Classroom(贪心)

    A. Silent Classroom time limit per test1 second memory limit per test256 megabytes inputstandard inp ...

  10. Python(Redis 中 String/List/Hash 类型数据操作)

    1.下载 redis 模块 pip install redis 2.redis 数据库两种连接方式 简单连接 decode_responses=True,写入和读取的键值对中的 value 为 str ...