锋利的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 相关文章推荐
js动态往表格的td中添加图片并注册事件
Jun 12 Javascript
Jquery实现兼容各大浏览器的Enter回车切换输入焦点的方法
Sep 01 Javascript
node.js中的fs.createWriteStream方法使用说明
Dec 17 Javascript
JSP基于Bootstrap分页显示实例解析
Jun 12 Javascript
利用ES6语法重构React组件详解
Mar 02 Javascript
VSCode 配置React Native开发环境的方法
Dec 27 Javascript
vue watch监听对象及对应值的变化详解
Feb 24 Javascript
用vue写一个仿简书的轮播图的示例代码
Mar 13 Javascript
vue项目中使用百度地图的方法
Jun 08 Javascript
Vue+Express实现登录状态权限验证的示例代码
May 05 Javascript
js滚轮事件 js自定义滚动条的实现
Jan 18 Javascript
详解Vue之事件处理
Jul 10 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
3种平台下安装php4经验点滴
2006/10/09 PHP
解决Laravel5.2 Auth认证退出失效的问题
2019/10/14 PHP
Asp.Net alert弹出提示信息的几种方法总结
2014/01/29 Javascript
js实现图片旋转的三种方法
2014/04/10 Javascript
关注jquery技巧提高jquery技能(前端开发必学)
2015/11/02 Javascript
使用vue与jquery实时监听用户输入状态的操作代码
2017/09/19 jQuery
vue引入新版 vue-awesome-swiper插件填坑问题
2018/01/25 Javascript
jquery根据name取得select选中的值实例(超简单)
2018/01/25 jQuery
微信小程序dom操作的替代思路实例分析
2018/12/06 Javascript
JavaScript中的一些实用小技巧总结
2019/04/07 Javascript
vue+elementUI 复杂表单的验证、数据提交方案问题
2019/06/24 Javascript
layui树形菜单动态遍历的例子
2019/09/23 Javascript
详解Python 模拟实现生产者消费者模式的实例
2017/08/10 Python
python保存字典和读取字典的实例代码
2019/07/07 Python
opencv之为图像添加边界的方法示例
2019/12/26 Python
Pycharm debug调试时带参数过程解析
2020/02/03 Python
基于python生成英文版词云图代码实例
2020/05/16 Python
浅谈matplotlib 绘制梯度下降求解过程
2020/07/12 Python
matplotlib相关系统目录获取方式小结
2021/02/03 Python
兰蔻英国官网:Lancome英国
2019/04/30 全球购物
英国经济型酒店品牌:Travelodge
2019/12/17 全球购物
Theflamel意大利:女士奢华服装、鞋子和配件
2020/01/11 全球购物
Tea Collection官网:一家位于旧金山的童装公司
2020/08/07 全球购物
写出一个方法实现冒泡排序
2016/07/08 面试题
护理自荐信范文
2013/10/05 职场文书
自荐信的五个重要部分
2013/10/29 职场文书
电信专业毕业生推荐信
2013/11/18 职场文书
宣传策划类求职信范文
2014/01/31 职场文书
市场拓展计划书
2014/05/03 职场文书
社区反邪教工作方案
2014/06/16 职场文书
4S店收银员岗位职责
2015/04/07 职场文书
统计员岗位职责范本
2015/04/14 职场文书
爱心捐款活动总结
2015/05/09 职场文书
2016年公司中秋节致辞
2015/11/26 职场文书
2016简单的租房合同范本
2016/03/18 职场文书
2019年大学生职业生涯规划书
2019/03/25 职场文书