锋利的jQuery 要点归纳(三) jQuery中的事件和动画(上:事件篇)


Posted in Javascript onMarch 24, 2010

一、事件

1 加载DOM

$(document).ready(function(){//...}) 
DOM加载完毕后执行,在可重复使用上区别于window.onload=function(){//...} 
$(window).load(function(){//...}) 
window内所有对象加载完毕后执行,几等同window.onload=function(){//...}。也可针对selector使用此方法

另:$(document).ready(function(){//...})的简写方式:$(function(){//...})或$().ready(function(){//...})

2 事件绑定

$("selector").bind() 
为元素绑定事件,格式:bind(type[,data],fn),可多次调用 
type事件类型包括:blur, focus, load, resize, scroll, unload, click, dbclick, mousedown, mouseup, mousemove, mouseover, mouseout, mouseenter, mouseleave, change, select, submit, keydown, keypress, keyup, error或者自定义事件 
简写方法:$("selector").bind(type,function(){//...})等价于$("selector").type(function(){//...}) 
可传递data参数以供unbind特定事件之用 
$("selector").is() 
判断方法

(外:方法多次重用可定义局部变量 var $x = $("selector").方法())

3 合成事件

$("selector").hover(enter,leave) 
模拟光标悬停事件,鼠标进入时触发enter事件,鼠标移出时触发leave事件(代替的是bind("mouseenter")和bind("mouseleave")) 
使用方法:$("selector").hover(function(){//enter case...},function(){//leave case...}) 
(外:IE6不支持除a标签外css的:hover伪类的问题——可用此hover事件作为hack来解决) 
$("selector").toggle(fn1,fn2,...,fnN) 
模拟鼠标连续单击事件,按照单击顺序按次序循环执行事件 
使用方法:$("selector").toggle(function(){//case1...},function(){//case2...},...,function(){//caseN}) 
特殊用法:切换元素可见状态,如元素隐藏,单击toggle触发元素可使之可见;元素可见,单击toggle触发元素使之隐藏

P108例:
<script> 
$(function(){ 
$("panel h5.head").toggle(function(){ 
$(this).next().toggle(); 
},function(){ 
$(this).next().toggle(); 
}) 
}) 
</script>

4 事件冒泡

$("selector").bind("type",function(event){//event:事件对象...})
event事件对象:只有此函数内部才能访问到,事件处理函数执行完毕后,事件对象就被销毁
event.stopPropagation()
在函数最后用来停止事件冒泡
P111例:

<script> 
$('span').bind("click",function(event){ 
var txt = $('msg').html() + "<p>内层span元素被单击</p>"; 
$('#msg').html(txt); 
event.stopPropagation(); 
}) 
</script> 
event.preventDefault()

阻止元素默认行为
例:验证表单(input为空阻止提交并提示)
<script> 
$(function(){ 
$("#submit").bind("click",function(event){ 
var username=$("#username").val(); 
if(username==""){ 
$("#msg").html("<p> 文本框的值不能为空</p>"); 
event.preventDefault(); 
} 
}); 
}) 
</script>

return false;
同时对对象事件停止冒泡和默认行为,等价于同时调用stopPrapagation()和preventDefault()
(外:事件捕获和事件冒泡是相反的过程,事件捕获是从DOM顶端往下开始触发,jQuery不支持,故本书从略)

5 事件对象的属性

event.type
获取事件类型
例:

<script> 
$("a").click(function(event){ 
alert(event.type); 
return false; 
}) 
</script>

上面返回"click"
event.target
获取触发事件的元素
例:
<script> 
$("a[href=http://baidu.com]").click(function(){ 
alert(event.target.href); 
return false; 
}) 
</script>

上面返回"http://baidu.com"
event.relatedTarget
访问事件相关元素
event.pageX / event.pageY
获取光标相对于页面的x坐标和y坐标
event.which
在鼠标单击事件中获取鼠标的左、中、右键;在键盘事件中获取键盘的按键(返回值1=鼠标左键;2=鼠标中键;3=鼠标右键)
event.metaKey
键盘事件中获取<ctrl>按键
event.originalEvent
指向原始的事件对象

6 移除事件

$("selector").unbind()
移除元素上的事件,格式:$("selector").unbind([type][,data]);(如果没有参数,则删除所有绑定的事件;如果提供了事件类型参数,则只删除该类型的绑定事件;如果把在绑定时传递的处理函数作为第二个参数,则只有这个特定的事件处理函数会被删除)
例:

<script> 
$(function(){ 
$('#btn').bind("click",myFun1=function(){ //先绑定 
$('#test').append("..."); 
}); 
}) 
</script> 
<script> 
$('#delOne').click(function(){ 
$('#btn').unbind("click",myFun1); //后删除 
}) 
</script>

$("selector").one()
绑定一个触发一次即被删除的事件,格式:$("selector").one(type[,data],fn);

7 模拟操作

$("selector").trigger("type");
模拟用户交互动作,简写方法:$("#selector").type(); 格式:$("selector").trigger(type[,data])
例:用单击替代鼠标经过

<script> 
$("selector").mouseover(function{//...}); 
$("selector2").click(function(){ 
$("selector").trigger("mouseover"); //或者$("selector").mouseover() 
}) 
</script>

自定义事件的例子
<script> 
$("selector").bind("myClick",function(){//...}); //绑定自定义事件 
$("selector").trigger("myClick"); //触发自定义事件 
</script> 
$("selector").trigger(type[,data])

可以数组形式传递参数给回调函数
P119例:
<script> 
$("#btn").bind("myClick",function(event,message1,message2){ 
$("#test").append("<p>"+message1+message2+"</p>"); 
}); 
$("#btn").trigger("myClick", ["我的自定义","事件"]); 
</script>

8 其他用法

$("selector").bind("type1 type2",function(){//...})
一次性绑定多个事件类型
P119值得一看的例子

<script> 
$(function(){ 
$("div").bind("mouseover mouseout",function(){ 
$(this).toggleClass("over"); //切换class 
}); 
}) 
</script>

$("selector").bind("type.命名空间",function(){//...})
为多个事件添加事件命名空间,便于管理,删除命名空间后,命名空间下的事件同时删除,如:
$("div").bind("mouseover.plugin",function(){//...})
$("div").bind("click.plugin",function(){//...})
$("div").unbind(".plugin");
$("selector").trigger("type!")
"!"用来选择匹配不包含在命名空间中的type方法
Javascript 相关文章推荐
自动最大化窗口的Javascript代码
May 22 Javascript
Javascript 按位与运算符 (&amp;)使用介绍
Feb 04 Javascript
z-blog SyntaxHighlighter 长代码无法换行解决办法(jquery)
Nov 16 Javascript
jQuery基于函数重载实现自定义Alert函数样式的方法
Jul 27 Javascript
jquery checkbox的相关操作总结
Oct 17 Javascript
jQuery弹出div层过2秒自动消失
Nov 29 Javascript
jQuery实现手机号正则验证输入及自动填充空格功能
Jan 02 jQuery
详解jQuery中的isPlainObject()使用方法
Feb 27 jQuery
Vue 中对图片地址进行拼接的方法
Sep 03 Javascript
使用javascript做时间倒数读秒功能的实例
Jan 23 Javascript
JS实现表单中点击小眼睛显示隐藏密码框中的密码
Apr 13 Javascript
Vue+Element ui 根据后台返回数据设置动态表头操作
Sep 21 Javascript
jQuery AJAX 调用WebService实现代码
Mar 24 #Javascript
jquery 仿QQ校友的DIV模拟窗口效果源码
Mar 24 #Javascript
Javascript中Eval函数的使用
Mar 23 #Javascript
JavaScript Eval 函数使用
Mar 23 #Javascript
js本身的局限性 别让javascript做太多事
Mar 23 #Javascript
js parentElement和offsetParent之间的区别
Mar 23 #Javascript
Javascript 变量作用域 两个可能会被忽略的小特性
Mar 23 #Javascript
You might like
FleaPHP框架数据库查询条件($conditions)写法总结
2016/03/19 PHP
javascript调试说明
2010/06/07 Javascript
jQuery的链式调用浅析
2010/12/03 Javascript
根据经纬度计算地球上两点之间的距离js实现代码
2013/03/05 Javascript
JS实现图片翻书效果示例代码
2013/09/09 Javascript
使用javascript实现ListBox左右全选,单选,多选,全请
2013/11/07 Javascript
JS使用单链表统计英语单词出现次数
2016/06/16 Javascript
JS快速实现移动端拼图游戏
2016/09/05 Javascript
利用JavaScript实现拖拽改变元素大小
2016/12/14 Javascript
JS中cookie的使用及缺点讲解
2017/05/13 Javascript
javascript checkbox/radio onchange不能兼容ie8处理办法
2017/06/13 Javascript
React入门教程之Hello World以及环境搭建详解
2017/07/11 Javascript
vue中appear的用法
2017/08/17 Javascript
Js 利用正则表达式和replace函数获取string中所有被匹配到的文本(推荐)
2018/10/28 Javascript
利用JavaScript将Excel转换为JSON示例代码
2019/06/14 Javascript
js实现坦克大战游戏
2020/02/24 Javascript
js实现轮播图特效
2020/05/28 Javascript
原生javascript如何实现共享onload事件
2020/07/03 Javascript
JavaScript常用进制转换及位运算实例解析
2020/10/14 Javascript
[03:15]2014DOTA2国际邀请赛 专访国士无双信心满满
2014/07/12 DOTA
[10:21]DOTA2-DPC中国联赛 正赛 PSG.LGD vs Aster 选手采访
2021/03/11 DOTA
Python中设置变量作为默认值时容易遇到的错误
2015/04/03 Python
python实现unicode转中文及转换默认编码的方法
2017/04/29 Python
Python网页正文转换语音文件的操作方法
2018/12/09 Python
详解python uiautomator2 watcher的使用方法
2019/09/09 Python
Python模块的定义,模块的导入,__name__用法实例分析
2020/01/07 Python
Keras 利用sklearn的ROC-AUC建立评价函数详解
2020/06/15 Python
英国运动服、设备及配件网站:DW Sports
2019/12/04 全球购物
JSP&Servlet技术面试题
2015/05/21 面试题
给朋友的道歉信
2014/01/09 职场文书
《自然之道》教学反思
2014/02/11 职场文书
寒假家长评语大全
2014/04/16 职场文书
2014年乡镇人大工作总结
2014/11/25 职场文书
学校三八妇女节活动总结
2015/02/06 职场文书
孩子满月酒答谢词
2015/09/30 职场文书
Win10本地连接不见了怎么恢复? win10系统电脑本地连接不见了解决方法
2023/01/09 数码科技