详解jQuery的核心函数和事件处理


Posted in jQuery onFebruary 18, 2022

事件

页面载入 

1.ready(fn)当DOM载入就绪可以查询及操纵时绑定一个要执行的函数

$(document).ready(function(){
  // 在这里写你的代码...
});
// 下面是简写
$(function($) {
  // 你可以在这里继续使用$作为别名...
});

2.事件处理 on(events,fn)在选择元素上绑定一个或多个事件的事件处理函数

// 给p标签添加点击事件监听
$("p").on("click", function(){
	alert( $(this).text() );
});
// 第二种写法 等效于上面
$("p").click(function(){
	alert( $(this).text() );
});

3.off(events,[fn])在选择元素上移除一个或多个事件的事件处理函数

// 移除p标签绑定的所有事件监听
$("p").off()
// 移除p标签绑定的click事件监听
$("p").off( "click")

4.bind(events,fn)为每个匹配元素的特定事件绑定事件处理函数

// 移除p标签绑定的所有事件监听
$("p").bind("click", function(){
  alert( $(this).text() );
});
// 同时绑定多个事件类型
$('#foo').bind('mouseenter mouseleave', function() {
  alert();
});

5.unbind(type,fn]])bind()的反向操作,从每一个匹配的元素中删除绑定的事件

// 把所有段落的所有事件取消绑定
$("p").unbind()
// 将段落的click事件取消绑定
$("p").unbind( "click" )

6.one(type,[data],fn)为每一个匹配元素的特定事件(像click)绑定一个一次性的事件处理函数

// 当所有段落被第一次点击的时候,显示所有其文本
$("p").one("click", function(){
  alert( $(this).text() );
});

事件委派 

1.delegate(selector,[type],[data],fn)指定的元素(属于被选元素的子元素)添加一个或多个事件处理程序,并规定当这些事件发生时运行的函数

<div style="background-color:red">
      <p>这是一个段落。</p>
      <button>请点击这里</button>
  </div>
// 当点击button时,隐藏或显示 p 元素
  $("div").delegate("button", "click", function () {
      $("p").slideToggle();
  });

详解jQuery的核心函数和事件处理

2.undelegate([selector,[type],fn])删除由 delegate() 方法添加的一个或多个事件处理程序

// 从p元素删除由 delegate() 方法添加的所有事件处理器
$("p").undelegate();
// 从p元素删除由 delegate() 方法添加的所有click事件处理器
$("p").undelegate( "click" )

事件切换 

1.hover([over,]out)一个模仿悬停事件(鼠标移动到一个对象上面及移出这个对象)的方法

over:鼠标移到元素上要触发的函数

out:鼠标移出元素要触发的函数

// 鼠标悬停的表格加上特定的类
$("td").hover(
  function () {
    $(this).addClass("hover");
  },
  function () {
    $(this).removeClass("hover");
  }
);

事件 

1.blur([[data],fn])当元素失去焦点时触发 blur 事件

// 鼠标悬停的表格加上特定的类
$("td").hover(
  function () {
    $(this).addClass("hover");
  },
  function () {
    $(this).removeClass("hover");
  }
);

2.change([[data],fn])当元素的值发生改变时,会发生 change 事件

// 触发被选元素的 change 事件
$(selector).change();

3.click([[data],fn])触发每一个匹配元素的click事件

// 触发页面内所有段落的点击事件
$("p").click();

4.dblclick([[data],fn])当双击元素时,会发生 dblclick 事件

// 给页面上每个段落的双击事件绑上 "Hello World!" 警告框
$("p").dblclick( function () { alert("Hello World!"); });

5.error([[data],fn])当元素遇到错误(没有正确载入)时,发生 error 事件

// 在服务器端记录JavaScript错误日志:
$(window).error(function(msg, url, line){
  jQuery.post("js_error_log.php", { msg: msg, url: url, line: line });
});

6.focus([[data],fn])当元素获得焦点时,触发 focus 事件

// 当页面加载后将 id 为 'login' 的元素设置焦点:
$(document).ready(function(){
  $("#login").focus();
});

7.focusin([data],fn)当元素获得焦点时,触发 focusin 事件

<p><input type="text" /> <span>focusout fire</span></p>
<p><input type="password" /> <span>focusout fire</span></p>
// 获得焦点后会触发动画
$("p").focusin(function() {
	$(this).find("span").css('display','inline').fadeOut(1000);
});

8.focusout([data],fn)当元素失去焦点时触发 focusout 事件

// 获得焦点后会触发动画
$("p").focusout(function() {
  $(this).find("span").css('display','inline').fadeOut(1000);
});

9.keydown([[data],fn])当键盘或按钮被按下时,发生 keydown 事件

// 在页面内对键盘按键做出回应,可以使用如下代码
$(window).keydown(function(event){
  switch(event.keyCode) {
    // ...
    // 不同的按键可以做不同的事情
    // 不同的浏览器的keycode不同
    // 更多详细信息:     http://unixpapa.com/js/key.html
    // ...
  }
});

10.keypress([[data],fn])当键盘或按钮被按下时,发生 keypress 事件

// 计算在输入域中的按键次数
$("input").keydown(function(){
  $("span").text(i+=1);
});

11.keyup([[data],fn])当按钮被松开时,发生 keyup 事件。它发生在当前获得焦点的元素上

// 当按下按键时,改变文本域的颜色
$("input").keyup(function(){
  $("input").css("background-color","#D6D6FF");
});

12.mousedown([[data],fn])当鼠标指针移动到元素上方,并按下鼠标按键时,会发生 mousedown 事件

// 当按下鼠标按钮时,隐藏或显示元素
$("button").mousedown(function(){
  $("p").slideToggle();
});

13.mouseenter([[data],fn])当鼠标指针穿过元素时,会发生 mouseenter 事件

// 当鼠标指针进入(穿过)元素时,改变元素的背景色
$("p").mouseenter(function(){
  $("p").css("background-color","yellow");
});

14.mouseleave([[data],fn])当鼠标指针离开元素时,会发生 mouseleave 事件

// 当鼠标指针离开元素时,改变元素的背景色$("p").mouseleave(function(){  $("p").css("background-color","#E9E9E4");});// 当鼠标指针离开元素时,改变元素的背景色
$("p").mouseleave(function(){
  $("p").css("background-color","#E9E9E4");
});

15.mousemove([[data],fn])当鼠标指针在指定的元素中移动时,就会发生 mousemove 事件

事件坐标

  • event.clientX, event.clientY相对于视口的左上角
  • event.pageX,event.pageY 相对于页面的左上角
  • event.offsetX,event.offsetY 相对于事件元素的左上角
// 获得鼠标指针在页面中的位置
$(document).mousemove(function(e){
  $("span").text(e.pageX + ", " + e.pageY);
});

16.mouseout([[data],fn])当鼠标指针从元素上移开时,发生 mouseout 事件

// 当鼠标从元素上移开时,改变元素的背景色:
$("p").mouseout(function(){
  $("p").css("background-color","#E9E9E4");
});

17.mouseover([[data],fn])当鼠标指针位于元素上方时,会发生 mouseover 事件

// 当鼠标指针位于元素上方时时,改变元素的背景色
$("p").mouseover(function(){
  $("p").css("background-color","yellow");
});

18.mouseup([[data],fn])当在元素上放松鼠标按钮时,会发生 mouseup 事件

// 当松开鼠标按钮时,隐藏或显示元素
$("button").mouseup(function(){
  $("p").slideToggle();
});

19.resize([[data],fn])当调整浏览器窗口的大小时,发生 resize 事件

// 改变页面窗口的大小时弹出警告窗
$(window).resize(function(){
  alert("Stop it!");
});

20.scroll([[data],fn])当用户滚动指定的元素时,会发生 scroll 事件

// 当页面滚动条变化时,执行的函数:
$(window).scroll( function() { 
 	 alert("Stop it!");
});

21.select([[data],fn])当 textarea 或文本类型的 input 元素中的文本被选择时,会发生 select 事件

// 触发所有input元素的select事件:
$("input").select();

22.submit([[data],fn])当提交表单时,会发生 submit 事件

// 提交本页的第一个表单:
$("form:first").submit();
// 阻止表单提交:
$("form").submit( function () {
  return false;
} );

23.unload([[data],fn])在当用户离开页面时,会发生 unload 事件

点击某个离开页面的链接

在地址栏中键入了新的 URL

使用前进或后退按钮

关闭浏览器

重新加载页面

// 页面卸载的时候弹出一个警告框:
$(window).unload( function () { alert("Bye now!"); } );

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注三水点靠木的更多内容!

jQuery 相关文章推荐
简单实现jQuery弹幕效果
May 06 jQuery
jQuery复合事件用法示例
Jun 10 jQuery
jQuery实现简单的回到顶部totop功能示例
Oct 16 jQuery
jQuery简单实现对数组去重及排序操作实例
Oct 31 jQuery
jquery中ajax请求后台数据成功后既不执行success也不执行error的完美解决方法
Dec 24 jQuery
jquery在启动页面时,自动加载数据的实例
Jan 22 jQuery
jQuery替换节点元素的操作方法
Mar 18 jQuery
jQuery实现炫丽的3d旋转星空效果
Jul 04 jQuery
原生JS forEach()和map()遍历的区别、兼容写法及jQuery $.each、$.map遍历操作
Feb 27 jQuery
jQuery事件blur()方法的使用实例讲解
Mar 30 jQuery
jquery实现垂直手风琴菜单
Mar 04 jQuery
jQuery实现增删改查
Dec 22 jQuery
jQuery实现广告显示和隐藏动画
jQuery ajax - getScript() 方法和getJSON方法
May 14 #jQuery
jquery插件实现悬浮的菜单
jquery插件实现代码雨特效
Apr 24 #jQuery
jquery插件实现搜索历史
Apr 24 #jQuery
jquery插件实现图片悬浮
jQuery实现影院选座订座效果
You might like
PHP获取当前页面URL函数实例
2014/10/22 PHP
浅析PHP开发规范
2018/02/05 PHP
Jquery 设置标题的自动翻转
2009/10/03 Javascript
node.js中的fs.existsSync方法使用说明
2014/12/17 Javascript
js事件处理程序跨浏览器解决方案
2016/03/27 Javascript
基于JavaScript实现微信抢红包功能
2017/07/20 Javascript
react-native使用react-navigation进行页面跳转导航的示例
2017/09/07 Javascript
浅谈react-native热更新react-native-pushy集成遇到的问题
2017/09/30 Javascript
使用vue实现简单键盘的示例(支持移动端和pc端)
2017/12/25 Javascript
Vue实现6位数密码效果
2018/08/18 Javascript
JS获取动态添加元素的方法详解
2019/07/31 Javascript
微信小程序可滑动月日历组件使用详解
2019/10/21 Javascript
javascript实现图片轮换动作方法
2020/08/07 Javascript
js实现复制粘贴的两种方法
2020/12/04 Javascript
[04:55]完美世界副总裁蔡玮:DOTA2的自由、公平与信任
2013/12/18 DOTA
使用numba对Python运算加速的方法
2018/10/15 Python
Python判断对象是否相等及eq函数的讲解
2019/02/25 Python
Python二叉树的镜像转换实现方法示例
2019/03/06 Python
浅谈Python2之汉字编码为unicode的问题(即类似\xc3\xa4)
2019/08/12 Python
Python面向对象中类(class)的简单理解与用法分析
2020/02/21 Python
python通用读取vcf文件的类(复制粘贴即可用)
2020/02/29 Python
python mysql 字段与关键字冲突的解决方式
2020/03/02 Python
Selenium及python实现滚动操作多种方法
2020/07/21 Python
python Scrapy框架原理解析
2021/01/04 Python
html5 更新图片颜色示例代码
2014/07/29 HTML / CSS
canvas 下载二维码和图片加水印的方法
2018/03/21 HTML / CSS
详解html5 postMessage解决跨域通信的问题
2018/08/17 HTML / CSS
美国最大的香水连锁店官网:Perfumania
2016/08/15 全球购物
美国便宜的横幅和标志印刷在线:Best of Signs
2019/05/29 全球购物
定制别致的瑜伽垫:Sugarmat
2019/06/21 全球购物
保密承诺书范文
2014/03/27 职场文书
2014最新开业庆典策划方案(5篇)
2014/09/15 职场文书
党员个人整改措施
2014/10/24 职场文书
党员个人整改方案及措施
2014/10/25 职场文书
《黄山奇石》教学反思
2016/02/18 职场文书
Go归并排序算法的实现方法
2022/04/06 Golang