jQuery(基础用法,选择器,$(this))

jQuery 介绍

什么是jQuery ?

jQuery,顾名思义,也就是JavaScript 和查询(Query),它就是辅助JavaScript 开发的js 类库。

jQuery 核心思想!!!

它的核心思想是write less,do more(写得更少,做得更多),所以它实现了很多浏览器的兼容问题。

jQuery 流行程度

jQuery 现在已经成为最流行的JavaScript 库,在世界前10000 个访问最多的网站中,有超过55%在使用
jQuery。

jQuery 好处!!!

jQuery 是免费、开源的,jQuery 的语法设计可以使开发更加便捷,例如操作文档对象、选择DOM 元素、制作动画效果、事件处理、使用Ajax 以及其他功能

jQuery 的初体验!!!

需求:使用jQuery 给一个按钮绑定单击事件?

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
<script type="text/javascript" src="../script/jquery-1.7.2.js"></script>
<script type="text/javascript">
// window.onload = function () {
     
     
// var btnObj = document.getElementById("btnId");
// // alert(btnObj);//[object HTMLButtonElement] ====>>> dom 对象
// btnObj.onclick = function () {
     
     
// alert("js 原生的单击事件");
// }
// }
$(function () {
     
      // 表示页面加载完成之后,相当window.onload = function () {}
var $btnObj = $("#btnId"); // 表示按id 查询标签对象
$btnObj.click(function () {
     
      // 绑定单击事件
alert("jQuery 的单击事件");
});
});
</script>
</head>
<body>
<button id="btnId">SayHello</button>
</body>
</html>

写法总结

<script type="text/javascript" src="../script/jquery-1.7.2.js"></script>
<script type="text/javascript">
// window.onload = function () {
    
    
// var btnObj = document.getElementById("btnId");
// // alert(btnObj);//[object HTMLButtonElement] ====>>> dom 对象
// btnObj.onclick = function () {
    
    
// alert("js 原生的单击事件");
// }
// }
$(function () {
    
     // 表示页面加载完成之后,相当window.onload = function () {}
var $btnObj = $("#btnId"); // 表示按id 查询标签对象
$btnObj.click(function () {
    
     // 绑定单击事件
alert("jQuery 的单击事件");
});
});
</script>

常见问题?

  1. 使用jQuery 一定要引入jQuery 库吗?
    答案: 是,必须

  2. jQuery 中的$到底是什么?
    答案: 它是一个函数

  3. 怎么为按钮添加点击响应函数的?
    答案:
    3.1使用jQuery 查询到标签对象
    3.2使用标签对象.click( function(){} );

jQuery 核心函数($)

$ 是jQuery 的核心函数,能完成jQuery 的很多功能。$ ()就是调用$这个函数

  1. 传入参数为[ 函数] 时:$(function(){ });
    表示页面加载完成之后。相当于window.onload = function(){}

  2. 传入参数为[ HTML 字符串] 时:
    会对我们创建这个html 标签对象

  3. 传入参数为[ 选择器字符串] 时:

$(“#id 属性值”); id 选择器,根据id 查询标签对象
$(“标签名”); 标签名选择器,根据指定的标签名查询标签对象
$(“.class 属性值”); 类型选择器,可以根据class 属性查询标签对象

  1. 传入参数为[ DOM 对象] 时:
    会把这个dom 对象转换为jQuery 对象

$(function)
相当于:
$(document).ready(function(){
});

jQuery 对象和dom 对象区分

什么是jQuery 对象,什么是dom 对象

Dom 对象

  1. 通过getElementById()查询出来的标签对象是Dom 对象
  2. 通过getElementsByName()查询出来的标签对象是Dom 对象
  3. 通过getElementsByTagName()查询出来的标签对象是Dom 对象 通过createElement()方法创建的对象,是Dom 对象
  4. DOM 对象Alert 出来的效果是:[object HTML 标签名Element]

jQuery 对象

  1. 通过JQuery 提供的API 创建的对象,是JQuery 对象
  2. 通过JQuery 包装的Dom 对象,也是JQuery 对象
  3. 通过JQuery 提供的API 查询到的对象,是JQuery 对象
  4. jQuery 对象Alert 出来的效果是:[object Object]

问题:jQuery 对象的本质是什么?

jQuery 对象是dom 对象的数组+ jQuery 提供的一系列功能函数

jQuery 对象和Dom 对象使用区别

jQuery 对象不能使用DOM 对象的属性和方法
DOM 对象也不能使用jQuery 对象的属性和方法

Dom 对象和jQuery 对象互转

  1. dom 对象转化为jQuery 对象(*重点)
    ①先有DOM 对象
    ②$( DOM 对象) 就可以转换成为jQuery 对象

  2. jQuery 对象转为dom 对象(*重点)
    ①先有jQuery 对象
    ②jQuery 对象[下标]取出相应的DOM 对象
    在这里插入图片描述

过滤选择器

基本过滤器:

:first 获取第一个元素
:last 获取最后个元素
:not(selector) 去除所有与给定选择器匹配的元素
:even 匹配所有索引值为偶数的元素,从0 开始计数
:odd 匹配所有索引值为奇数的元素,从0 开始计数
:eq(index) 匹配一个给定索引值的元素
:gt(index) 匹配所有大于给定索引值的元素
:lt(index) 匹配所有小于给定索引值的元素
:header 匹配如h1, h2, h3 之类的标题元素
:animated 匹配所有正在执行动画效果的元素

案例:

$(function () {
    
    
					//1.选择 id 为 one 的元素 "background-color","#bbffaa"
					$("#btn1").click(function () {
    
    
						// css() 方法 可以设置和获取样式
						$("#one").css("background-color","#bbffaa");
					});

					//2.选择 class 为 mini 的所有元素
					$("#btn2").click(function () {
    
    
						$(".mini").css("background-color","#bbffaa");
					});

					//3.选择 元素名是 div 的所有元素
					$("#btn3").click(function () {
    
    
						$("div").css("background-color","#bbffaa");
					});

					//4.选择所有的元素
					$("#btn4").click(function () {
    
    
						$("*").css("background-color","#bbffaa");
					});

					//5.选择所有的 span 元素和id为two的元素
					$("#btn5").click(function () {
    
    
						$("span,#two").css("background-color","#bbffaa");
					});
				});

内容过滤器:

:contains(text) 匹配包含给定文本的元素
:empty 匹配所有不包含子元素或者文本的空元素
:parent 匹配含有子元素或者文本的元素
:has(selector) 匹配含有选择器所匹配的元素的元素

代码案例

$(document).ready(function(){
    
    
				//1.选择 含有文本 'di' 的 div 元素
				$("#btn1").click(function(){
    
    
					$("div:contains('di')").css("background", "#bbffaa");
				});

				//2.选择不包含子元素(或者文本元素) 的 div 空元素
				$("#btn2").click(function(){
    
    
					$("div:empty").css("background", "#bbffaa");
				});

				//3.选择含有 class 为 mini 元素的 div 元素
				$("#btn3").click(function(){
    
    
					$("div:has(.mini)").css("background", "#bbffaa");
				});

				//4.选择含有子元素(或者文本元素)的div元素
				$("#btn4").click(function(){
    
    
					$("div:parent").css("background", "#bbffaa");
				});
			});

属性过滤器:

[attribute] 匹配包含给定属性的元素。
[attribute=value] 匹配给定的属性是某个特定值的元素
[attribute!=value] 匹配所有不含有指定的属性,或者属性不等于特定值的元素。
[attribute^=value] 匹配给定的属性是以某些值开始的元素
[attribute$=value] 匹配给定的属性是以某些值结尾的元素
[attribute*=value] 匹配给定的属性是以包含某些值的元素
[attrSel1][attrSel2][attrSelN] 复合属性选择器,需要同时满足多个条件时使用。

$(function() {
    
    
		//1.选取含有 属性title 的div元素
		$("#btn1").click(function() {
    
    
			$("div[title]").css("background", "#bbffaa");
		});
		//2.选取 属性title值等于'test'的div元素
		$("#btn2").click(function() {
    
    
			$("div[title='test']").css("background", "#bbffaa");
		});
		//3.选取 属性title值不等于'test'的div元素(*没有属性title的也将被选中)
		$("#btn3").click(function() {
    
    
			$("div[title!='test']").css("background", "#bbffaa");
		});
		//4.选取 属性title值 以'te'开始 的div元素
		$("#btn4").click(function() {
    
    
			$("div[title^='te']").css("background", "#bbffaa");
		});
		//5.选取 属性title值 以'est'结束 的div元素
		$("#btn5").click(function() {
    
    
			$("div[title$='est']").css("background", "#bbffaa");
		});
		//6.选取 属性title值 含有'es'的div元素
		$("#btn6").click(function() {
    
    
			$("div[title*='es']").css("background", "#bbffaa");
		});
		
		//7.首先选取有属性id的div元素,然后在结果中 选取属性title值 含有'es'的 div 元素
		$("#btn7").click(function() {
    
    
			$("div[id][title*='es']").css("background", "#bbffaa");
		});
		//8.选取 含有 title 属性值, 且title 属性值不等于 test 的 div 元素
		$("#btn8").click(function() {
    
    
			$("div[title][title!='test']").css("background", "#bbffaa");
		});
	});

表单过滤器:

:input 匹配所有input, textarea, select 和button 元素
:text 匹配所有文本输入框
:password 匹配所有的密码输入框
:radio 匹配所有的单选框
:checkbox 匹配所有的复选框
:submit 匹配所有提交按钮
:image 匹配所有img 标签
:reset 匹配所有重置按钮
:button 匹配所有input type=button 按钮
:file 匹配所有input type=file 文件上传
:hidden 匹配所有不可见元素display:none 或input type=hidden

表单对象属性过滤器:

:enabled 匹配所有可用元素
:disabled 匹配所有不可用元素
:checked 匹配所有选中的单选,复选,和下拉列表中选中的option 标签对象
:selected 匹配所有选中的option

$(function(){
    
    
			
		   //1.对表单内 可用input 赋值操作
			$("#btn1").click(function(){
    
    
				// val()可以操作表单项的value属性值
				// 它可以设置和获取
				$(":text:enabled").val("我是万能的程序员");
			});
			//2.对表单内 不可用input 赋值操作
			$("#btn2").click(function(){
    
    
				$(":text:disabled").val("管你可用不可用,反正我是万能的程序员");
			});
			//3.获取多选框选中的个数  使用size()方法获取选取到的元素集合的元素个数
			$("#btn3").click(function(){
    
    
				alert( $(":checkbox:checked").length );
			});
			//4.获取多选框,每个选中的value值
			$("#btn4").click(function(){
    
    
				// 获取全部选中的复选框标签对象
				var $checkboies = $(":checkbox:checked");
				// 老式遍历
				// for (var i = 0; i < $checkboies.length; i++){
    
    
				// 	alert( $checkboies[i].value );
				// }

				// each方法是jQuery对象提供用来遍历元素的方法
				// 在遍历的function函数中,有一个this对象,这个this对象,就是当前遍历到的dom对象
				$checkboies.each(function () {
    
    
					alert( this.value );
				});

			});
			//5.获取下拉框选中的内容  
			$("#btn5").click(function(){
    
    
				// 获取选中的option标签对象
				var $options = $("select option:selected");
				// 遍历,获取option标签中的文本内容
				$options.each(function () {
    
    
					// 在each遍历的function函数中,有一个this对象。这个this对象是当前正在遍历到的dom对象
					alert(this.innerHTML);
				});
			});
		})	;

jQuery 元素筛选

eq() 获取给定索引的元素功能跟:eq() 一样
first() 获取第一个元素功能跟:first 一样
last() 获取最后一个元素功能跟:last 一样
filter(exp) 留下匹配的元素
is(exp) 判断是否匹配给定的选择器,只要有一个匹配就返回,true
has(exp) 返回包含有匹配选择器的元素的元素功能跟:has 一样
not(exp) 删除匹配选择器的元素功能跟:not 一样
children(exp) 返回匹配给定选择器的子元素功能跟parent>child 一样
find(exp) 返回匹配给定选择器的后代元素功能跟ancestor descendant 一样
next() 返回当前元素的下一个兄弟元素功能跟prev + next 功能一样
nextAll() 返回当前元素后面所有的兄弟元素功能跟prev ~ siblings 功能一样
nextUntil() 返回当前元素到指定匹配的元素为止的后面元素
parent() 返回父元素
prev(exp) 返回当前元素的上一个兄弟元素
prevAll() 返回当前元素前面所有的兄弟元素
prevUnit(exp) 返回当前元素到指定匹配的元素为止的前面元素
siblings(exp) 返回所有兄弟元素
add() 把add 匹配的选择器的元素添加到当前jquery 对象中过滤选择器

jQuery中$(this)

那么,用到这个jquery里,也算是蛮简单的.举两个例子,一个是单个对象,一个是li元素集合
例1:

$("#btnConfirm").click(function(){
    
    
alert($(this).val()); //看这里,this代表的其实就是这个ID为btnConfirm的按钮,因为你现在点击的是ID为btnConfirm的按钮,那么this就是它
});

例子2:

$("ul li").each(function(){
    
    
alert( $(this).text()); 
//这里的this代表的是迭代的每个li元素,因为每次迭代,得到的都是一个<li>元素,那么这个时候this 就代表着这个当前的<li>元素
})

在事件的function 函数中,有一个this 对象,这个this 对象是当前正在响应事件的dom 对象

猜你喜欢

转载自blog.csdn.net/weixin_46168350/article/details/111825740