jQuery 選擇器允許對 HTML 元素組或單個元素進行操作。
jQuery 選擇器基於元素的 id、類、類型、屬性、屬性值等"查找"(或選擇)HTML 元素。 它基於已經存在的CSS 選擇器,除此之外,它還有一些自定義的選擇器。
jQuery 中所有選擇器都以美元符號開頭:$()。
如果你有興趣可以參考本文章源碼素材和我一起寫:鏈接:https://pan.baidu.com/s/1Qy2myx-Vi7XDib34kPdBrQ
提取碼:z4c7
1. 基本選擇器
1. 標籤選擇器(元素選擇器)
* 語法: $("html標籤名") 獲得所有匹配標籤名稱的元素
2. id選擇器
* 語法: $("#id的屬性值") 獲得與指定id屬性值匹配的元素
3. 類選擇器
* 語法: $(".class的屬性值") 獲得與指定的class屬性值匹配的元素
4. 並集選擇器:
* 語法: $("選擇器1,選擇器2....") 獲取多個選擇器選中的所有元素
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>基本選擇器</title>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<script src="../js/jquery-3.3.1.min.js"></script>
<style type="text/css">
div,span{
width: 180px;
height: 180px;
margin: 20px;
background: #9999CC;
border: #000 1px solid;
float:left;
font-size: 17px;
font-family:Roman;
}
div .mini{
width: 50px;
height: 50px;
background: #CC66FF;
border: #000 1px solid;
font-size: 12px;
font-family:Roman;
}
div .mini01{
width: 50px;
height: 50px;
background: #CC66FF;
border: #000 1px solid;
font-size: 12px;
font-family:Roman;
}
</style>
<script type="text/javascript">
$(function () {
// <input type="button" value="保存" class="mini" name="ok" class="mini" />
// <input type="button" value="改變 id 爲 one 的元素的背景色爲 紅色" id="b1"/>
$("#b1").click(function () {
$("#one").css("backgroundColor","pink");
});
$("#b2").click(function () {
// <input type="button" value=" 改變元素名爲 <div> 的所有元素的背景色爲 紅色" id="b2"/>
$("div").css("backgroundColor","pink");
})
$("#b3").click(function () {
// <input type="button" value=" 改變 class 爲 mini 的所有元素的背景色爲 紅色" id="b3"/>
$(".mini").css("backgroundColor","pink");
})
$("#b4").click(function () {
// <input type="button" value=" 改變所有的<span>元素和 id 爲 two 的元素的背景色爲紅色" id="b4"/>
$("span,#two").css("backgroundColor","pink");
})
})
</script>
</head>
<body>
<input type="button" value="保存" class="mini" name="ok" class="mini" />
<input type="button" value="改變 id 爲 one 的元素的背景色爲 紅色" id="b1"/>
<input type="button" value=" 改變元素名爲 <div> 的所有元素的背景色爲 紅色" id="b2"/>
<input type="button" value=" 改變 class 爲 mini 的所有元素的背景色爲 紅色" id="b3"/>
<input type="button" value=" 改變所有的<span>元素和 id 爲 two 的元素的背景色爲紅色" id="b4"/>
<h1>有一種奇蹟叫堅持</h1>
<h2>自信源於努力</h2>
<div id="one">
id爲one
</div>
<div id="two" class="mini" >
id爲two class是 mini
<div class="mini" >class是 mini</div>
</div>
<div class="one" >
class是 one
<div class="mini" >class是 mini</div>
<div class="mini" >class是 mini</div>
</div>
<div class="one" >
class是 one
<div class="mini01" >class是 mini01</div>
<div class="mini" >class是 mini</div>
</div>
<span class="spanone">class爲spanone的span元素</span>
<span class="mini">class爲mini的span元素</span>
<input type="text" value="zhang" id="username" name="username">
</body>
</html>
運行結果:
點擊按鈕一:
點擊按鈕二:
點擊按鈕三:
點擊按鈕四:
2. 層級選擇器
1. 後代選擇器
* 語法: $("A B ") 選擇A元素內部的所有B元素
2. 子選擇器
* 語法: $("A > B") 選擇A元素內部的所有B子元素
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>層次選擇器</title>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<script src="../js/jquery-3.3.1.min.js"></script>
<style type="text/css">
div,span{
width: 180px;
height: 180px;
margin: 20px;
background: #9999CC;
border: #000 1px solid;
float:left;
font-size: 17px;
font-family:Roman;
}
div .mini{
width: 50px;
height: 50px;
background: #CC66FF;
border: #000 1px solid;
font-size: 12px;
font-family:Roman;
}
div .mini01{
width: 50px;
height: 50px;
background: #CC66FF;
border: #000 1px solid;
font-size: 12px;
font-family:Roman;
}
</style>
<script type="text/javascript">
$(function () {
// <input type="button" value=" 改變 <body> 內所有 <div> 的背景色爲紅色" id="b1"/>
$("#b1").click(function () {
$("body div").css("backgroundColor","pink");
});
// <input type="button" value=" 改變 <body> 內子 <div> 的背景色爲 紅色" id="b2"/>
$("#b2").click(function () {
$("body>div").css("backgroundColor","pink");
});
});
</script>
</head>
<body>
<input type="button" value="保存" class="mini" name="ok" class="mini" />
<input type="button" value=" 改變 <body> 內所有 <div> 的背景色爲紅色" id="b1"/>
<input type="button" value=" 改變 <body> 內子 <div> 的背景色爲 紅色" id="b2"/>
<h1>有一種奇蹟叫堅持</h1>
<h2>自信源於努力</h2>
<div id="one">
id爲one
</div>
<div id="two" class="mini" >
id爲two class是 mini
<div class="mini" >class是 mini</div>
</div>
<div class="one" >
class是 one
<div class="mini" >class是 mini</div>
<div class="mini" >class是 mini</div>
</div>
<div class="one">
class是 one
<div class="mini01" >class是 mini01</div>
<div class="mini" >class是 mini</div>
</div>
<span class="spanone"> span
</span>
</body>
</html>
運行結果:
運行前:
點擊按鈕一:
點擊按鈕二:
3. 屬性選擇器
1. 屬性名稱選擇器
* 語法: $("A[屬性名]") 包含指定屬性的選擇器
2. 屬性選擇器
* 語法: $("A[屬性名='值']") 包含指定屬性等於指定值的選擇器
3. 複合屬性選擇器
* 語法: $("A[屬性名='值'][]...") 包含多個屬性條件的選擇器
4.
*語法:$["A[屬性名!='值']"]匹配所有不含有指定的屬性,或者屬性不等於特定值的元素。
5.
*語法:$["A[屬性名^='值']"]匹配給定的屬性是以某些值開始的元素
6.
*語法:$["A[屬性名$='值']"]匹配給定的屬性是以某些值結尾的元素
7.
*語法:$["A[屬性名*='值']"]匹配給定的屬性是以包含某些值的元素
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>屬性過濾選擇器</title>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<script src="../js/jquery-3.3.1.min.js"></script>
<style type="text/css">
div,span{
width: 180px;
height: 180px;
margin: 20px;
background: #9999CC;
border: #000 1px solid;
float:left;
font-size: 17px;
font-family:Roman;
}
div .mini{
width: 50px;
height: 50px;
background: #CC66FF;
border: #000 1px solid;
font-size: 12px;
font-family:Roman;
}
div .mini01{
width: 50px;
height: 50px;
background: #CC66FF;
border: #000 1px solid;
font-size: 12px;
font-family:Roman;
}
div.visible{
display:none;
}
</style>
<script type="text/javascript">
$(function () {
// <input type="button" value=" 含有屬性title 的div元素背景色爲粉色" id="b1"/>
$("#b1").click(function () {
$("div[title]").css("backgroundColor","pink");
});
// <input type="button" value=" 屬性title值等於test的div元素背景色爲粉色" id="b2"/>
$("#b2").click(function () {
$("div[title='test']").css("backgroundColor","pink");
});
// <input type="button" value=" 屬性title值不等於test的div元素(沒有屬性title的也將被選中)背景色爲粉色" id="b3"/>
$("#b3").click(function () {
$("div[title!='test']").css("backgroundColor","pink");
});
// <input type="button" value=" 屬性title值 以te開始 的div元素背景色爲粉色" id="b4"/>
$("#b4").click(function () {
$("div[title^='te']").css("backgroundColor","pink");
});
// <input type="button" value=" 屬性title值 以est結束 的div元素背景色爲粉色" id="b5"/>
$("#b5").click(function () {
$("div[title$='est']").css("backgroundColor","pink");
});
// <input type="button" value="屬性title值 含有es的div元素背景色爲粉色" id="b6"/>
$("#b6").click(function () {
$("div[title*='es']").css("backgroundColor","pink");
});
// <input type="button" value="選取有屬性id的div元素,然後在結果中選取屬性title值含有“es”的 div 元素背景色爲粉色" id="b7"/>
$("#b7").click(function () {
$("div[id][title*='es']").css("backgroundColor","pink");
});
})
</script>
</head>
<body>
<input type="button" value="保存" class="mini" name="ok" class="mini" />
<input type="button" value=" 含有屬性title 的div元素背景色爲粉色" id="b1"/>
<input type="button" value=" 屬性title值等於test的div元素背景色爲粉色" id="b2"/>
<input type="button" value=" 屬性title值不等於test的div元素(沒有屬性title的也將被選中)背景色爲粉色" id="b3"/>
<input type="button" value=" 屬性title值 以te開始 的div元素背景色爲粉色" id="b4"/>
<input type="button" value=" 屬性title值 以est結束 的div元素背景色爲粉色" id="b5"/>
<input type="button" value="屬性title值 含有es的div元素背景色爲粉色" id="b6"/>
<input type="button" value="選取有屬性id的div元素,然後在結果中選取屬性title值含有“es”的 div 元素背景色爲粉色" id="b7"/>
<div id="one">
id爲one div
</div>
<div id="two" class="mini" title="test">
id爲two class是 mini div title="test"
<div class="mini" >class是 mini</div>
</div>
<div class="visible" >
class是 one
<div class="mini" >class是 mini</div>
<div class="mini" >class是 mini</div>
</div>
<div class="one" title="test02">
class是 one title="test02"
<div class="mini01" >class是 mini01</div>
<div class="mini" style="margin-top:0px;">class是 mini</div>
</div>
<div class="visible" >
這是隱藏的
</div>
<div class="one">
</div>
<div id="mover" >
動畫
</div>
<input type="text" value="zhang" id="username" name="username">
</body>
</html>
運行結果:
運行前:
點擊按鈕一:
點擊按鈕二:
點擊按鈕三:
點擊按鈕四:
點擊按鈕五:
點擊按鈕六:
點擊按鈕七:
4. 過濾選擇器
1. 首元素選擇器
* 語法: :first 獲得選擇的元素中的第一個元素
2. 尾元素選擇器
* 語法: :last 獲得選擇的元素中的最後一個元素
3. 非元素選擇器
* 語法: :not(selector) 不包括指定內容的元素
4. 偶數選擇器
* 語法: :even 偶數,從 0 開始計數
5. 奇數選擇器
* 語法: :odd 奇數,從 0 開始計數
6. 等於索引選擇器
* 語法: :eq(index) 指定索引元素
7. 大於索引選擇器
* 語法: :gt(index) 大於指定索引元素
8. 小於索引選擇器
* 語法: :lt(index) 小於指定索引元素
9. 標題選擇器
* 語法: :header 獲得標題(h1~h6)元素,固定寫法
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>基本過濾選擇器</title>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<script src="../js/jquery-3.3.1.min.js"></script>
<style type="text/css">
div,span{
width: 180px;
height: 180px;
margin: 20px;
background: #9999CC;
border: #000 1px solid;
float:left;
font-size: 17px;
font-family:Roman;
}
div .mini{
width: 50px;
height: 50px;
background: #CC66FF;
border: #000 1px solid;
font-size: 12px;
font-family:Roman;
}
div .mini01{
width: 50px;
height: 50px;
background: #CC66FF;
border: #000 1px solid;
font-size: 12px;
font-family:Roman;
}
</style>
<script type="text/javascript">
$(function () {
// <input type="button" value=" 改變第一個 div 元素的背景色爲 粉色" id="b1"/>
$("#b1").click(function () {
$("div:first").css("backgroundColor","pink");
})
// <input type="button" value=" 改變最後一個 div 元素的背景色爲 粉色" id="b2"/>
$("#b2").click(function () {
$("div:last").css("backgroundColor","pink");
})
// <input type="button" value=" 改變class不爲 one 的所有 div 元素的背景色爲 粉色" id="b3"/>
$("#b3").click(function () {
$("div:not(.one)").css("backgroundColor","pink");
})
// <input type="button" value=" 改變索引值爲偶數的 div 元素的背景色爲 粉色" id="b4"/>
$("#b4").click(function () {
$("div:even").css("backgroundColor","pink");
})
// <input type="button" value=" 改變索引值爲奇數的 div 元素的背景色爲 粉色" id="b5"/>
$("#b5").click(function () {
$("div:odd").css("backgroundColor","pink");
})
// <input type="button" value=" 改變索引值爲大於 3 的 div 元素的背景色爲 粉色" id="b6"/>
$("#b6").click(function () {
$("div:gt(3)").css("backgroundColor","pink");
})
// <input type="button" value=" 改變索引值爲等於 3 的 div 元素的背景色爲 粉色" id="b7"/>
$("#b7").click(function () {
$("div:eq(3)").css("backgroundColor","pink");
})
// <input type="button" value=" 改變索引值爲小於 3 的 div 元素的背景色爲 粉色" id="b8"/>
$("#b8").click(function () {
$("div:lt(3)").css("backgroundColor","pink");
})
// <input type="button" value=" 改變所有的標題元素的背景色爲 粉色" id="b9"/>
$("#b9").click(function () {
$(":header").css("backgroundColor","pink");
})
})
</script>
</head>
<body>
<input type="button" value="保存" class="mini" name="ok" class="mini" />
<input type="button" value=" 改變第一個 div 元素的背景色爲 粉色" id="b1"/>
<input type="button" value=" 改變最後一個 div 元素的背景色爲 粉色" id="b2"/>
<input type="button" value=" 改變class不爲 one 的所有 div 元素的背景色爲 粉色" id="b3"/>
<input type="button" value=" 改變索引值爲偶數的 div 元素的背景色爲 粉色" id="b4"/>
<input type="button" value=" 改變索引值爲奇數的 div 元素的背景色爲 粉色" id="b5"/>
<input type="button" value=" 改變索引值爲大於 3 的 div 元素的背景色爲 粉色" id="b6"/>
<input type="button" value=" 改變索引值爲等於 3 的 div 元素的背景色爲 粉色" id="b7"/>
<input type="button" value=" 改變索引值爲小於 3 的 div 元素的背景色爲 粉色" id="b8"/>
<input type="button" value=" 改變所有的標題元素的背景色爲 粉色" id="b9"/>
<h1>有一種奇蹟叫堅持</h1>
<h2>自信源於努力</h2>
<div id="one">
id爲one
</div>
<div id="two" class="mini" >
id爲two class是 mini
<div class="mini" >class是 mini</div>
</div>
<div class="one" >
class是 one
<div class="mini" >class是 mini</div>
<div class="mini" >class是 mini</div>
</div>
<div class="one" >
class是 one
<div class="mini01" >class是 mini01</div>
<div class="mini" >class是 mini</div>
</div>
</body>
</html>
運行結果:
點擊按鈕一
點擊按鈕二
點擊按鈕三
點擊按鈕四
點擊按鈕五
點擊按鈕六
點擊按鈕七
點擊按鈕八
點擊按鈕九
5. 表單過濾選擇器
1. 可用元素選擇器
* 語法: :enabled 獲得可用元素
2. 不可用元素選擇器
* 語法: :disabled 獲得不可用元素
3. 選中選擇器
* 語法: :checked 獲得單選/複選框選中的元素
4. 選中選擇器
* 語法: :selected 獲得下拉框選中的元素
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>表單屬性過濾選擇器</title>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<script src="../js/jquery-3.3.1.min.js"></script>
<style type="text/css">
div,span{
width: 180px;
height: 180px;
margin: 20px;
background: #9999CC;
border: #000 1px solid;
float:left;
font-size: 17px;
font-family:Roman;
}
div .mini{
width: 50px;
height: 50px;
background: #CC66FF;
border: #000 1px solid;
font-size: 12px;
font-family:Roman;
}
div .mini01{
width: 50px;
height: 50px;
background: #CC66FF;
border: #000 1px solid;
font-size: 12px;
font-family:Roman;
}
#job{
margin: 20px;
}
#edu{
margin-top:-70px;
}
</style>
<script type="text/javascript">
$(function () {
// <input type="button" value=" 利用 jQuery 對象的 val() 方法改變表單內可用 <input> 元素的值" id="b1"/>
$("#b1").click(function () {
$("input[type='text']:enabled").val("aaaaaaaa");
});
// <input type="button" value=" 利用 jQuery 對象的 val() 方法改變表單內不可用 <input> 元素的值" id="b2"/>
$("#b2").click(function () {
$("input[type='text']:disabled").val("bbbbbbb");
});
// <input type="button" value=" 利用 jQuery 對象的 length 屬性獲取複選框選中的個數" id="b3"/>
$("#b3").click(function () {
alert($("input[type='checkbox']:checked").length);
});
// <input type="button" value=" 利用 jQuery 對象的 length 屬性獲取下拉框選中的個數" id="b4"/>
$("#b4").click(function () {
alert($("#job>option:selected").length);
});
})
</script>
</head>
<body>
<input type="button" value="保存" class="mini" name="ok" class="mini" />
<input type="button" value=" 利用 jQuery 對象的 val() 方法改變表單內可用 <input> 元素的值" id="b1"/>
<input type="button" value=" 利用 jQuery 對象的 val() 方法改變表單內不可用 <input> 元素的值" id="b2"/>
<input type="button" value=" 利用 jQuery 對象的 length 屬性獲取複選框選中的個數" id="b3"/>
<input type="button" value=" 利用 jQuery 對象的 length 屬性獲取下拉框選中的個數" id="b4"/>
<input type="text" value="不可用值1" disabled="disabled">
<input type="text" value="可用值1" >
<input type="text" value="不可用值2" disabled="disabled">
<input type="text" value="可用值2" >
<input type="checkbox" name="items" value="美容" >美容
<input type="checkbox" name="items" value="IT" >IT
<input type="checkbox" name="items" value="金融" >金融
<input type="checkbox" name="items" value="管理" >管理
<input type="radio" name="sex" value="男" >男
<input type="radio" name="sex" value="女" >女
<select name="job" id="job" multiple="multiple" size=4>
<option>程序員</option>
<option>中級程序員</option>
<option>高級程序員</option>
<option>系統分析師</option>
</select>
<select name="edu" id="edu">
<option>本科</option>
<option>博士</option>
<option>碩士</option>
<option>大專</option>
</select>
<br/>
<div id="two" class="mini" >
id爲two class是 mini div
<div class="mini" >class是 mini</div>
</div>
<div class="one" >
class是 one
<div class="mini" >class是 mini</div>
<div class="mini" >class是 mini</div>
</div>
<div class="one" >
class是 one
<div class="mini01" >class是 mini01</div>
<div class="mini" >class是 mini</div>
</div>
</body>
</html>
運行結果:
點擊按鈕一
點擊按鈕二
點擊按鈕三
點擊按鈕四
掌握以上選擇器就差不多能滿足平時需求了,如果還想了解更多可以查看API文檔。
國內在線JQuery API:http://jquery.cuishifeng.cn/