点击打开:

jquery系列教程1-选择器全解

jquery系列教程2-style样式操作全解

jquery系列教程3-DOM操作全解

jquery系列教程4-事件操作全解

jquery系列教程5-动画操作全解

jquery系列教程6-ajax的应用全解

jquery系列教程7-自定义jquery插件全解

jquery系列教程8-jquery插件大全

jquery中的事件操作全解:



事件冒泡,子元素事件会向父元素传递,触发父元素的同类事件

事件捕获,事件从最外层开始向内层传递,jquery不支持捕获,只能使用原生js才能使用事件捕获

DOM加载事件

DOM加载事件分为onload事件和ready事件。

//window.onload函数在页面所有内容加载完成后触发,只能执行最后一个window.onload函数
$(window).load(function(){         //等价于window.onload = function
    alert("加载完成");
});

//ready函数在DOM树加载完成后触发,可以同时执行多个ready函数。
$(document).ready(function(){      //$(document)可以简写成$(),  $(document).ready函数可以简写成$(function(){})
    alert("加载完成");
});

事件绑定

使用函数bind(type [,data],fn)绑定事件。

1、其中type表示事件类型:blur,focus,load,resize,scroll,unload,click,dblclick,mousedown,mouseup,mousemove,mouseout,mouseover,mouseenter,mouseleave,change,select,submit,keydown,keypress,keyup,error。

2、data表示传递给事件对象的额外数据,范围绑定的处理函数

$cr.bind("click",myfun = function(){                   //bind绑定事件,可以没有额外数据。可以将事件赋值给一个引用变量,在其他地方使用这个函数
    this.innerHTML;                                    //this表示绑定对象
    $(this).html();                                    //将this通过$转化为jquery对象,以便调用jquery函数
});

$cr.bind("click.mynamespace",function(){               //mynamespace用于表示事件的命名空间,是一个用于区别相同类型事件的不同函数.
});

$cr.bind("mouseover",function(event){                   //bind更换绑定事件,event事件对象,调用不用传递传参数,会自动拥有此参数。
    event.preventDefault();                             //阻止默认行为,如超链接自动跳转,提交按钮自动提交。
    event.stopPropagation();                            //停止事件冒泡。因为事件大部分默认是冒泡的
    return false;                                       //return false也代表了preventDefault和stopPropagation,可以代替他们
}).bind("mouseout",function(event){                     //对于没有返回值的对象函数,函数后可以继续进行访问,jquery特色的链式操作。
    event.type;                                         //事件类型
    event.target;                                       //触发事件的元素,此处相当远鼠标离开的元素
    event.relatedTarget;                                //相关元素,此处相当于鼠标进入的元素
    event.pageX+event.pageY;                            //光标相对于页面的位置,如果有滚动条要加上滚动条的位置
    event.which;                                        //鼠标按键(1,2,3,表示左右中键)或键盘按键
    event.metaKey;                                      //ctrl按键
});

$cr.bind("mouseover mouseout",function(){               //可以一次绑定多个事件
    alert("光标进出");
});

$cr.bind("myclick",function(event,message1,message2){   //为对象绑定自定义事件,不会自动触发,必须代码触发。
    alert(message1.toString()+message2.toString());
});

$cr.one("click",function(){                              //对只执行一次,就解除绑定的事件,使用one绑定
});

解除绑定

$cr.unbind();                                       //删除元素所有事件
$cr.unbind("click");                                //删除元素所有点击事件,因为元素可以同时绑定多个点击事件
$cr.unbind("mouseover").unbind("mouseout");         //解除绑定,支持链式写法
$cr.unbind("click",myfun);                          //删除元素myfun点击事件
$cr.unbind(".mynamespace");                         //删除所有具有此命名空间的绑定函数

合成事件

jquery特有的hover和toggle方法。

$cr.hover(function(){                         //hover用来模拟光标悬停事件,同时设置光标进入和离开函数,与上面同时设置mouseover和mouseout函数效果相同
    printf("光标进入");
},function(){
    printf("光标离开");
});

$cr.toggle(function(){                         //toggle模拟鼠标连续点击
    printf("第一次点击");
},function(){
    printf("第二次点击");
},function(){
    printf("第三次点击");
});

模拟操作

$cr.trigger("click");                             //触发事件,包括绑定事件和默认事件
$cr.trigger("click!");                            //触发没有命名空间的事件
$cr.trigger("myclick",['我的自定义','事件']);       //触发自定义事件,以数组的形式传递参数
$cr.click();                                      //触发事件,包括绑定事件和默认事件
$cr.triggerHandler("focus");                      //触发绑定事件,但不触发默认事件

jquery系列教程4-事件操作全解的更多相关文章

  1. jquery系列教程2-style样式操作全解

    全栈工程师开发手册 (作者:栾鹏) 快捷链接: jquery系列教程1-选择器全解 jquery系列教程2-style样式操作全解 jquery系列教程3-DOM操作全解 jquery系列教程4-事件 ...

  2. jquery系列教程6-ajax的应用全解

    点击打开: jquery系列教程1-选择器全解 jquery系列教程2-style样式操作全解 jquery系列教程3-DOM操作全解 jquery系列教程4-事件操作全解 jquery系列教程5-动 ...

  3. jquery系列教程1-选择器全解

    全栈工程师开发手册 (作者:栾鹏) 快捷链接: jquery系列教程1-选择器全解 jquery系列教程2-style样式操作全解 jquery系列教程3-DOM操作全解 jquery系列教程4-事件 ...

  4. js系列教程1-数组操作全解

    全栈工程师开发手册 (作者:栾鹏) 快捷链接: js系列教程1-数组操作全解 js系列教程2-对象和属性全解 js系列教程3-字符串和正则全解 js系列教程4-函数与参数全解 js系列教程5-容器和算 ...

  5. css系列教程1-选择器全解

    全栈工程师开发手册 (作者:栾鹏) 一个demo学会css css系列教程1-选择器全解 css系列教程2-样式操作全解 css选择器全解: css选择器包括:基本选择器.属性选择器.伪类选择器.伪元 ...

  6. jquery系列教程3-DOM操作全解

    全栈工程师开发手册 (作者:栾鹏) 快捷链接: jquery系列教程1-选择器全解 jquery系列教程2-style样式操作全解 jquery系列教程3-DOM操作全解 jquery系列教程4-事件 ...

  7. jquery系列教程7-自定义jquery插件全解:对象函数、全局函数、选择器

    点击打开: jquery系列教程1-选择器全解 jquery系列教程2-style样式操作全解 jquery系列教程3-DOM操作全解 jquery系列教程4-事件操作全解 jquery系列教程5-动 ...

  8. [js高手之路] es6系列教程 - 对象功能扩展详解

    第一:字面量对象的方法,支持缩写形式 //es6之前,这么写 var User = { name : 'ghostwu', showName : function(){ return this.nam ...

  9. Android Studio系列教程五--Gradle命令详解与导入第三方包

    Android Studio系列教程五--Gradle命令详解与导入第三方包 2015 年 01 月 05 日 DevTools 本文为个人原创,欢迎转载,但请务必在明显位置注明出处!http://s ...

随机推荐

  1. CCNA基础知识摘录

    cisco设备的启动要点: 1.检测硬件(保存在rom) 2.载入软件(IOS)(保存在Flash) 3.调入配置文件(密码,IP地址,路由协议都保存在此)(此文件保存在NVRAM) 0x2102:正 ...

  2. 转:【Java并发编程】之十:使用wait/notify/notifyAll实现线程间通信的几点重要说明

    转载请注明出处:http://blog.csdn.net/ns_code/article/details/17225469    在Java中,可以通过配合调用Object对象的wait()方法和no ...

  3. MySQL (七)--视图、数据库备份和还原

    1 视图 视图:View,是一种有结构(有行有列)但是没结果(结构中不真实存放的数据)的虚拟表,虚拟表的结构来源不是自己定义,而是从对应的基表中产生(视图的数据来源). 示例脚本: CREATE TA ...

  4. 【1414软工助教】团队作业9——测试与发布(Beta版本) 得分榜

    题目 团队作业9--测试与发布(Beta版本) 往期成绩 个人作业1:四则运算控制台 结对项目1:GUI 个人作业2:案例分析 结对项目2:单元测试 团队作业1:团队展示 团队作业2:需求分析& ...

  5. Git和Github使用

    什么是Git? Git 是一个快速.可扩展的分布式版本控制系统,它具有极为丰富的命令集,对内部系统提供了高级操作和完全访问. 版本控制 简单地说,就是将在本地开发的代码,定时推送到服务器.每一次修改, ...

  6. 团队作业4---第一次项目冲刺(ALpha)版本 第五天

    一.Daily Scrum Meeting照片 二.燃尽图 三.项目进展 a.完成所有基础功能 b.正在进行测试调试 四.困难与问题 1.根据测试需求功能,部分基础功能不能实现,性能不达标,后续已完成 ...

  7. C#程序及批处理中确定windows操作系统的方法

    先上一段代码: private void Form1_Load(object sender, EventArgs e) { OperatingSystem os = Environment.OSVer ...

  8. 201521123007《Java程序设计》第11周学习总结

    1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多线程相关内容. 2. 书面作业 本次PTA作业题集多线程 1. 互斥访问与同步访问 完成题集4-4(互斥访问)与4-5(同步访问) ...

  9. 201521123113《Java程序设计》第14周学习总结

    1. 本周学习总结 1.1 以你喜欢的方式(思维导图.Onenote或其他)归纳总结多数据库相关内容. JDBC体系架构: 2. 书面作业 Q1. MySQL数据库基本操作 1.1 建立数据库test ...

  10. Thrift教程初级篇——thrift安装环境变量配置第一个实例

    前言: 因为项目需要跨语言,c++客户端,web服务端,远程调用等需求,所以用到了RPC框架Thrift,刚开始有点虚,第一次接触RPC框架,后来没想到Thrift开发方便上手快,而且性能和稳定性也不 ...