jQuery学习(三)
事件
on方法可以将一个事件绑定在jQuery对象上,当你的操作触发了这些事件时,便会调用你所绑定的函数。
例如,给某个超链接绑定点击事件。
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<script src="./js/jquery-1.12.0.js"></script>
<script>
$(document).ready(function(){
var a = $('a');
a.on('click', function(){
alert('Hello Word');
});
});
</script>
<title>Event</title>
</head>
<body>
<a href="#0">Click</a>
</body>
除了用on()以外,还可以直接用click来绑定点击事件。
<script>
$(document).ready(function(){
var a = $('a');
a.click(function(){
alert('Hello');
});
});
</script>
鼠标事件
click: 鼠标单击时触发;
dblclick:鼠标双击时触发;
mouseenter:鼠标进入时触发;
mouseleave:鼠标移出时触发;
mousemove:鼠标在DOM内部移动时触发;
hover:鼠标进入和退出时触发两个函数,相当于mouseenter加上mouseleave。
键盘事件
键盘事件仅作用在当前焦点的DOM上,通常是<input>和<textarea>。
keydown:键盘按下时触发; keyup:键盘松开时触发; keypress:按一次键后触发。
其他事件
focus:当DOM获得焦点时触发;
blur:当DOM失去焦点时触发;
change:当<input>、<select>或<textarea>的内容改变时触发;
submit:当<form>提交时触发;
ready:当页面被载入并且DOM树完成初始化后触发。
其中,ready仅作用于document对象上,在页面DOM树构建完成后触发。
正如上述代码所示,除了能够用on绑定ready事件外,ready事件也可以像click一样被简写。甚至能被更简单的写为:
<script>
$(function(){
var a = $('a');
a.click(function(){
alert('Hello');
});
});
</script>
而且这种写法更为常见。
如果想获得事件的其他内容,可以在function传入变量e来获取。
取消绑定:
和on()相反的是,off()可以帮我们取消jQuery对象上的事件绑定,
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<script src="./js/jquery-1.12.0.js"></script>
<script>
$(function(){
var a = $('a');
a.click(function(){
alert('Hello');
});
var bt = $('button');
bt.click(function(){
a.off('click');
alert('event_off');
});
});
</script>
<title>Event</title>
</head>
<body>
<a href="#0">Click</a>
<button>event_off</button>
</body>
点击Button时取消了链接的点击事件,再点击链接不会出现提示框。
实际上,这里我们将a链接上的点击事件绑定函数全部取消了,如果只想取消某一个函数,那么我们在绑定时,就不能够采用匿名函数。并且在取消时,将函数对象也作为参数传入。
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<script src="./js/jquery-1.12.0.js"></script>
<script>
$(function(){
var click_f2 = function(){
alert('hello 2');
};
var a = $('a');
a.click(function(){
alert('Hello');
});
a.click(click_f2); var bt = $('button');
bt.click(function(){
a.off('click',click_f2);
alert('click_f2 off');
});
});
</script>
<title>Event</title>
</head>
<body>
<a href="#0">Click</a>
<button>event_off</button>
</body>
这段代码中,我们只取消绑定了click_f2,而Hello仍然正常提示。同时我们可以发现绑定事件响应的先后顺序是根据绑定的先后来的。
事件通常是由用户操作触发,如果我们希望代码可以直接触发事件,则可用trigger(),这样能够避免我们写很多重复的代码。
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<script src="./js/jquery-1.12.0.js"></script>
<script>
$(function(){
var a = $('a');
a.click(function(){
alert('Hello');
}); var bt = $('button');
bt.click(function(){
a.trigger('click');
});
});
</script>
<title>Event</title>
</head>
<body>
<a href="#0">Click</a>
<button>event_off</button>
</body>
当我们点击按钮时,我们在代码内部触发了a的点击事件,因此也能弹出Hello。
动画:
我们已经知道了通过show()和hide()方法,可以让一个jQuery对象消失或者隐藏。但是当我们给方法传入一个参数时,页面就能呈现渐变的效果,一般传入的参数是毫秒数,但是'slow'和'fast'也能作为参数传入。
show()和hide()是对象由左上角逐渐收起或是展开,而slideUp()和slideDown()则是垂直方向的收起和展开。
fadeIn()和fadeOut()表示渐入渐出的效果。
同时,jQuery还通过animate()支持自定义动画效果。给animate传入最终的CSS样式和变化的时间,则可以在指定时间内渐变成最后的样式。同时,animate还能够传入回调函数,在动画结束后被调用。
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Animate</title>
<script src='./js/jquery-1.12.0.js'></script>
<script>
$(function(){
var bt = $('button');
var div = $('#test-animate');
bt.click(function(){
div.animate({
width: '256px',
height: '256px'
},3000,function(){
alert('animate done');
});
});
});
</script>
</head>
<body>
<div id='test-animate'></div>
<button>change CSS</button>
</body>
jQuery学习(三)的更多相关文章
- Jquery 学习三
		一.each语句 1.each语句的功能 在jQuery中,通过$函数获取的都是jQuery对象.通过测试可知,jQuery对象是一个类数组的特殊对象,其是DOM对象的集合.而each语句就是专门用于 ... 
- JQuery学习三(隐式迭代和节点遍历)
		在JQuery中根据id获取控件,如果输入id错误是不报错的. 必要时可以通过写判断语句进行判断是否id写错 <!DOCTYPE html> <html xmlns="ht ... 
- jQuery学习三——事件
		代码如下: <!DOCTYPE html> <html> <head> <title>jquery事件</title> </head& ... 
- jquery 学习(三) - 遍历操作
		HTML代码 <p>1111</p> <p>1111</p> <p>1111</p> <p>1111</p&g ... 
- jQuery学习(三)——选择器总结
		1.基本选择器 id选择器:$(“#id名称”); 元素选择器:$(“元素名称”); 类选择器:$(“.类名”); 通配符:* 多个选择器共用(并集) 案例代码: <!DOCTYPE html& ... 
- 初步学习jquery学习笔记(三)
		jQuery学习笔记三 jquery停止动画 stop函数的初步功能 <!DOCTYPE html> <html lang="en"> <head&g ... 
- jQuery学习-事件之绑定事件(三)
		在上一篇<jQuery学习-事件之绑定事件(二)>我们了解了jQuery的dispatch方法,今天我们来学习下handlers 方法: handlers: function( event ... 
- jquery学习笔记(三):事件和应用
		内容来自[汇智网]jquery学习课程 3.1 页面加载事件 在jQuery中页面加载事件是ready().ready()事件类似于就JavaScript中的onLoad()事件,但前者只要页面的DO ... 
- jQuery学习笔记(一)jQuery选择器
		目录 jQuery选择器的优点 基本选择器 层次选择器 过滤选择器 表单选择器 第一次写博客,希望自己能够长期坚持,以写博客的方式作为总结与复习. 最近一段时间开始学习jQuery,通过写一个jQue ... 
随机推荐
- MTK Android Framework用SystemProperties通过JNI调用访问系统属性
			1.导包 import android.os.SystemProperties; 2. Android SystemProperties设置/读取 #设置 Systemproperties.set(n ... 
- Linux基础篇,系统服务(service)的管理
			一.服务是什么? 用白话文说,服务就是"常驻在内存中的进程",用来提供一些系统或网络功能. 二.service和daemon的区别与联系 因为服务(service)本质上来说也是程 ... 
- Mac 系统root
			没错,你没看错,就是root mac系统安装件的时候,你有没有遇到过这种情况 总之,就是安装不上软件,肿么办? 网上解觉办法是: 进入系统偏好设置,设置为允许任何人,可是进去后这样: 别着急,打开命令 ... 
- tf.train.MomentumOptimizer 优化器
			tf.train.MomentumOptimizer( learning_rate, momentum, use_locking=False, use_nesterov=False, name='Mo ... 
- tf.nn.relu6 激活函数
			tf.nn.relu6(features,name=None) 计算校正线性6:min(max(features, 0), 6) 参数: features:一个Tensor,类型为float,doub ... 
- 360众测考试 Drupal 漏洞 CVE-2018-7600 远程代码执行-复现
			0x00 前言 昨天360众测遇到的一个题 今天自己搭环境复现一下,希望对大家有帮助 0x01 漏洞简介 Drupal是一个开源内容管理系统(CMS),全球超过100万个网站(包括政府,电子零售,企业 ... 
- ASP.NET Core中配置监听URLs的五种方式
			原文: 5 ways to set the URLs for an ASP.NET Core app 作者: Andrew Lock 译者: Lamond Lu 默认情况下,ASP. NET Core ... 
- 设计模式系列之迭代器模式(Iterator Pattern)——遍历聚合对象中的元素
			模式概述 模式定义 模式结构图 模式伪代码 模式改进 模式应用 模式在JDK中的应用 模式在开源项目中的应用 模式总结 说明:设计模式系列文章是读刘伟所著<设计模式的艺术之道(软件开发人员内功修 ... 
- tensorflow--filter、strides
			最近还在看<TensorFlow 实战Google深度学习框架第二版>这本书,根据第六章里面对于卷基层和池化层的介绍可以发现,在执行 tf.nn.conv2d 和 tf.nn.max_po ... 
- notepad++批量每行加字符
			移动光标到头 选择正则 输入^ 下面输入需要加的文本. 点替换 
