jQuery
jQuery是js的一个库,方便我们使用,提高开发效率
jQurey的特点
1.链式编程
2.隐式迭代:在方法的内部进行循环便利,不用我们自己在进行循环
jQurey的优点
一款轻量级的JS框架。jQuery核心js文件才几十kb,不会影响页面加载速度。
丰富的DOM选择器,jQuery的选择器用起来很方便,比如要找到某个DOM对象的相邻元素,JS可能要写好几行代码,而jQuery一行代码就搞定了,再比如要将一个表格的隔行变色,jQuery也是一行代码搞定。
链式表达式。jQuery的链式操作可以把多个操作写在一行代码里,更加简洁。
事件、样式、动画支持。jQuery还简化了js操作css的代码,并且代码的可读性也比js要强。
Ajax操作支持。jQuery简化了AJAX操作,后端只需返回一个JSON格式的字符串就能完成与前端的通信。
跨浏览器兼容。jQuery基本兼容了现在主流的浏览器,不用再为浏览器的兼容问题而伤透脑筋。
插件扩展开发。jQuery有着丰富的第三方的插件,例如:树形菜单、日期控件、图片切换插件、弹出窗口等等基本前端页面上的组件都有对应插件,并且用jQuery插件做出来的效果很炫,并且可以根据自己需要去改写和封装插件,简单实用。
jQuery对象
jQuery对象就是通过jQuery包装DOM对象后产生的对象。jQuery对象是 jQuery独有的。如果一个对象是 jQuery对象,那么它就可以使用jQuery里的方法:例如$(“#i1”).html()。
$("#i1").html()的意思是:获取id值为 i1的元素的html代码。其中 html()是jQuery里的方法。
相当于: document.getElementById("i1").innerHTML;
虽然 jQuery对象是包装 DOM对象后产生的,但是 jQuery对象无法使用 DOM对象的任何方法,同理 DOM对象也没不能使用 jQuery里的方法。
基本选择器
id选择器:
$("#id")
标签选择器:
$("tagName")
class选择器:
$(".className")
配合使用:
$("div.c1") // 找到有c1 class类的div标签
所有元素选择器:
$("*")
组合选择器:
$("#id, .className, tagName")
层级选择器
x和y可以为任意选择器
$("x y");// x的所有后代y(子子孙孙)
$("x > y");// x的所有儿子y(儿子)
$("x + y")// 找到所有紧挨在x后面的y
$("x ~ y")// x之后所有的兄弟y
基本筛选器
基本选择器
# 根据标签名查
$('ul')
# 查询标签内部的子节点
$('ul li')
# 查询标签内部的第一个节点--first
$('ul li:first')
# 查询标签内部的第一个节点--last
$('ul li:last')
# 按索引号查询--eq
$('ul li:eq(1)')
# 查询索引为偶数的节点--even # 此时0为偶数
$('ul li:even')
# 查询索引为奇数的节点--odd
$('ul li:odd')
# 查询大于索引的节点--gt
$('ul li:gt(索引号)')
# 查询小于索引号的节点--lt
$('ul li:lt(索引号)')
# 不显示不需要的节点
$('div span:has(".c1")') # 表示在查询 div 中的结果中不显示c1
# 筛选后代中是否有查询的节点
$('div:has(".c1")') # 判断div中有没有 c1 的节点
# 总结:" : " 后边跟的是判断条件,查询出来的结果是数组的行式
属性选择器
可以根据自己定义的属性来进行查找,查找的方式是使用 [ ] 来查找
# 基础版
$('[username]') # 查询全局中含有username的节点
# 升级版
$('[username="wang"]') # 查询全局中username='wang'的节点
# 豪华版
$('span[username="wang"]') # 查询span中username='wang'的节点
表单选择器
# 表单元素:需要用户输入选择的部分,就是HTML中的表单
# 常见的表单标签:input,select,label,textarea
$(':text') # 查询type类型是test的节点
$(':password') # 查询type类型是password的节点
$(':file') # 查询type类型是文件的节点
$(':radio') # 查询含有radio属性的节点
$(':checkbox') # 查询含有checkbox属性的节点 checkbox默认选中
$(':submit') # 查询type类型是sumbit类型的节点
$(':reset') # 查询type类型是reset类型的节点
$(':button') # 查询含有button类型的节点
注意:使用表单筛选器进行查询的时候,使用$(':checkbox')的时候会将selece也找到,这是在使用的时候的一个bug,所以在查询select的时候需要使用$(':select')
下一个元素:
$("#id").next()
$("#id").nextAll()
$("#id").nextUntil("#i2")
上一个元素:
$("#id").prev()
$("#id").prevAll()
$("#id").prevUntil("#i2")
父亲元素:
$("#id").parent()
$("#id").parents() // 查找当前元素的所有的父辈元素
$("#id").parentsUntil() // 查找当前元素的所有的父辈元素,直到遇到匹配的那个元素为止。
儿子和兄弟元素:
$("#id").children();// 儿子们
$("#id").siblings();// 兄弟们
查找
搜索所有与指定表达式匹配的元素。这个函数是找出正在处理的元素的后代元素的好方法。
$("div").find("p")
等价于$("div p")
筛选
筛选出与指定表达式匹配的元素集合。这个方法用于缩小匹配的范围。用逗号分隔多个表达式。
$("div").filter(".c1") // 从结果集中过滤出有c1样式类的
等价于 $("div.c1")
补充:
.first() // 获取匹配的第一个元素
.last() // 获取匹配的最后一个元素
.not() // 从匹配元素的集合中删除与指定表达式匹配的元素
.has() // 保留包含特定后代的元素,去掉那些不含有指定后代的元素。
.eq() // 索引值等于指定值的元素
筛选器方法
直接通过锁定需要进行操作的标签下,直接对这个标签内的内容进行查询
# 先查找到需要进行操作的标签对象
> var $spanEle = $('span')[0] # 注意:此时拿到的是标签对象
> $($spanEle) # 此时是一个jQuery对象
常用的筛选器方法
注意:在使用筛选器的时候要注意区分是jQuery对象还是标签对象
左侧菜单栏
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="x-ua-compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>左侧菜单示例</title>
<style>
.left {
position: fixed;
left: 0;
top: 0;
20%;
height: 100%;
background-color: rgb(47, 53, 61);
}
.right {
80%;
height: 100%;
}
.menu {
color: white;
}
.title {
text-align: center;
padding: 10px 15px;
border-bottom: 1px solid #23282e;
}
.items {
background-color: #181c20;
}
.item {
padding: 5px 10px;
border-bottom: 1px solid #23282e;
}
.hide {
display: none;
}
</style>
</head>
<body>
<div class="left">
<div class="menu">
<div class="item">
<div class="title">菜单一</div>
<div class="items">
<div class="item">111</div>
<div class="item">222</div>
<div class="item">333</div>
</div>
</div>
<div class="item">
<div class="title">菜单二</div>
<div class="items hide">
<div class="item">111</div>
<div class="item">222</div>
<div class="item">333</div>
</div>
</div>
<div class="item">
<div class="title">菜单三</div>
<div class="items hide">
<div class="item">111</div>
<div class="item">222</div>
<div class="item">333</div>
</div>
</div>
</div>
</div>
<div class="right"></div>
<script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.min.js"></script>
<script>
$(".title").click(function (){ // jQuery绑定事件
// 隐藏所有class里有.items的标签
// $(".items").addClass("hide"); //批量操作
// $(this).next().removeClass("hide");
// jQuery链式操作
$(this).next().removeClass('hide').parent().siblings().find('.items').addClass('hide')
});
</script>
操作标签
样式操作
标签操作
位置操作
实例:当滚动条滑动到某一个位置的时候会自动执行某一指令
offset()// 获取匹配元素在当前窗口的相对偏移或设置元素位置
position()// 获取匹配元素相对父元素的偏移
scrollTop()// 获取匹配元素相对滚动条顶部的偏移
scrollLeft()// 获取匹配元素相对滚动条左侧的偏移
返回顶部实例
文本操作
jQuery的文本操作与js的文本操作实现的方法上是一样的
获取文本框值的操作:
$('div').val() # 查询值
$('div').val('wang') # 添加值
自定义登录校验实例
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta http-equiv="x-ua-compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>文本操作之登录验证</title>
<style>
.error {
color: red;
}
</style>
</head>
<body>
<form action="">
<div>
<label for="input-name">用户名</label>
<input type="text" id="input-name" name="name">
<span class="error"></span>
</div>
<div>
<label for="input-password">密码</label>
<input type="password" id="input-password" name="password">
<span class="error"></span>
</div>
<div>
<input type="button" id="btn" value="提交">
</div>
</form>
<script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.min.js"></script>
<script>
$("#btn").click(function () {
var username = $("#input-name").val();
var password = $("#input-password").val();
if (username.length === 0) {
$("#input-name").siblings(".error").text("用户名不能为空");
}
if (password.length === 0) {
$("#input-password").siblings(".error").text("密码不能为空");
}
})
</script>
</body>
</html>
属性操作
用于ID等或自定义属性:
attr(attrName)// 返回第一个匹配元素的属性值
attr(attrName, false/true)// 为所有匹配元素设置一个属性值
attr({k1: v1, k2:v2})// 为所有匹配元素设置多个属性值
removeAttr()// 从每一个匹配的元素中删除一个属性
用于checkbox和radio
prop() // 获取属性
removeProp() // 移除属性
prop和attr的区别:
attr所指的属性是HTML标签属性可以认为attr是显式的。
prop所指的是DOM对象属性,而prop是隐式的。
文档处理
添加到指定元素内部的后面
$(A).append(B)// 把B追加到A
$(A).appendTo(B)// 把A追加到B
添加到指定元素内部的前面
$(A).prepend(B)// 把B前置到A
$(A).prependTo(B)// 把A前置到B
添加到指定元素外部的后面
$(A).after(B)// 把B放到A的后面
$(A).insertAfter(B)// 把A放到B的后面
添加到指定元素外部的前面
$(A).before(B)// 把B放到A的前面
$(A).insertBefore(B)// 把A放到B的前面
移除和清空元素
remove()// 从DOM中删除所有匹配的元素。
empty()// 删除匹配的元素集合中所有的子节点。
替换
replaceWith()
replaceAll()
克隆
clone()// 参数
克隆实例
jQurey事件
与js中的事件相同,当进行某些操作的时候会触发某些动作
jQurey常见的事件
click(function(){...}) # 点击事件
hover(function(){...}) # 悬浮事件
blur(function(){...}) # 移除事件
focus(function(){...}) # 聚焦事件
change(function(){...}) # 内容与变化
keyup(function(){...}) # 键位上下操作
按住shift实现批量操作实例
jQurey绑定事件语法
1.$(选择器).事件名(function(){事件代码})
2.$(选择器).on('事件名',function(){事件代码} ) # 用处更广,事件委托用
input实时监听事件
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>input实时监控</title>
</head>
<body>
<script src="jQuery.js"></script>
<input type="text" id="i1">
<script>
$("#i1").on("input propertychange",function(){
alert($(this).val());
})
</script>
</body>
阻止标签默认事件
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>阻止默认事件</title>
</head>
<body>
<form action="">
<button id="b1">点我</button>
</form>
<script src="jQuery.js"></script>
<script>
$("#b1").click(function(e){
alert(123);
e.preventDefault();
})
</script>
</body>
</html>
阻止冒泡事件
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>阻止事件冒泡</title>
</head>
<body>
<div>
我是div
<p>我是p
<span>点我</span>
</p>
</div>
<script src="jQuery.js"></script>
<script>
$("span").click(function (e) {
alert("span");
e.stopPropagation();
});
$("p").click(function (e) {
alert("p");
e.stopPropagation()
});
$("div").click(function () {
alert("div");
})
</script>
</body>
</html>
事件委托
事件委托 将特定的事件 委托给标签内部指定的元素 (标签即可以是提前写的 也可以是后期动态添加的)