jQuery 選擇器簡介
創(chuàng)新互聯(lián)堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站設(shè)計、成都網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的貴溪網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
jQuery 選擇器允許對 HTML 元素組或單個元素進(jìn)行操作。
jQuery 選擇器基于元素的 id、類、類型、屬性、屬性值等"查找"(或選擇)HTML 元素。 它基于已經(jīng)存在的 CSS 選擇器,除此之外,它還有一些自定義的選擇器。
jQuery 中所有選擇器都以美元符號開頭:$()。
1 .基本選擇器
$("#test")???????????? ?? 選擇id值為test的元素,id值是唯一的所以返回單個元素。
$("div")?????????????? ?? 選擇所有的div標(biāo)簽元素,返回div元素數(shù)組
$(".myclass")????????? ?? 選擇使用myclass類的css的所有元素
$("*")???????????????? ?? 選取所有元素。
$("#test,div,.myclass")? ??? 選取多個元素。
2.層次選擇器
$("div span") ? 選取div里的所有span元素
$("div span")?? ? 選取div元素下元素名是span的子元素
$("#one +div")?? ? 選取id為one的元素的下一個div同輩元素??? 等同于$("#one").next("div")
$("#one~div")??? ? 選取id為one的元素的元素后面的所有div同輩元素??? 等同于$("#one").nextAll("div")
$("#one").siblings("div") ?? 獲取id為one的元素的所有div同輩元素(不管前后)
$("#one").prev("div") 獲取id為one的元素的前面緊鄰的同輩div元素
所以 獲取元素范圍大小順序依次為:
$("#one").siblings("div")$("#one~div")$("#one +div")
或是
$("#one").siblings("div")$("#one").nextAll("div")$("#one").next("div")
3.基本過濾選擇器
$("div:first")?????????????? 選取所有div元素中第1個div元素
$("div:last")?????????????????? 選取所有div元素中最后一個div元素
$("input:not(.myClass)")??????? 選取class不是myClass的input元素
$("input:even")???????????????? 選取索引是偶數(shù)的input元素(索引從0開始)
$("input:odd")????????????????? 選取索引是基數(shù)的input元素(索引從0開始)
$("input:eq(2)")??????????????? 選取索引等于2的input元素
$("input:gt(4)")??????????????? 選取索引大于4的input元素
$("input:lt(4)")??????????????? 選取索引小于4的input元素
$(":header")??????????????????? 過濾掉所有標(biāo)題元素,例如:h1、h2、h3等
$("div:animated")?????????????? 選取正在執(zhí)行動畫的div元素
$(":focus")???????????????????? 選取當(dāng)前獲取焦點(diǎn)的元素
4.內(nèi)容過濾選擇器
$("div:contains('Name')")?????? 選取所有div中含有'Name'文本的元素
$("div:empty")????????????????? 選取不包含子元素(包括文本元素)的div空元素
$("div:has(p)")???????????????? 選取所有含有p元素的div元素
$("div:parent")???????????????? 選取擁有子元素的(包括文本元素)div元素
5.可見性過濾選擇器
$("div:hidden")???????????????? 選取所有不可見的div元素
$("div:visible")??????????????? 選取所有可見的div元素
6.屬性過濾選擇器
$("div[id]")????????????? 選取所有擁有屬性id的元素
$("input[name='test']")???? 選取所有的name屬性等于'test'的input元素
$("input[name!='test']")? 選取所有的name屬性不等于'test'的input元素
$("input[name^='news']")??????? 選取所有的name屬性以'news'開頭的input元素
$("input[name$='news']")??????? 選取所有的name屬性以'news'結(jié)尾的input元素
$("input[name*='news']")??????? 選取所有的name屬性包含'news'的input元素
$("div[title|='en']")?????????? 選取屬性title等于'en'或以'en'為前綴(該字符串后跟一個連字符'-')的div元素
$("div[title~='en']")?????????? 選取屬性title用空格分隔的值中包含字符en的div元素
$("div[id][title$='test']")???? 選取擁有屬性id,并且屬性title以'test'結(jié)束的div元素
7.子元素過濾選擇器
$("div .one:nth-child(2)")?????? 選取class為'one'的div父元素下的第2個子元素
$("div span:first-child")??????? 選取每個div中的第1個span元素
$("div span:last-child")???????? 選取每個div中的最后一個span元素
$("div button:only-child")?????? 在div中選取是唯一子元素的button元素
8.表單對象屬性過濾選擇器
$("#form1 :enabled")???????????? 選取id為'form1'的表單內(nèi)所有可用元素
$("#form2 :disabled")??????????? 選取id為'form2'的表單內(nèi)所有不可用元素
$("input :checked")????????????? 選取所有被選中的input元素
$("select option:selected")????? 選取所有的select 的子元素中被選中的元素
9.表單選擇器
$(":input")????????????????????? 選取所有input,textarea,select 和 button元素
$(":text")??????????????????? 選取所有的單行文本框
$(":password")?????????????????? 選取所有的密碼框
$(":radio")????????????????????? 選取所有單的選框
$(":checkbox")?????????????????? 選取所有的多選框
$(":submit")???????????????????? 選取所有的提交按鈕
$(":image")????????????????????? 選取所有的圖像按鈕
$(":reset")????????????????????? 選取所有的重置按鈕
$(":button")???????????????????? 選取所有的按鈕
$(":file")?????????????????????? 選取所有的上傳域
$(":hidden")???????????????????? 選取所有不可見元素
可以
$(this).find("hidden")
hidden是標(biāo)簽嗎?不是標(biāo)簽?zāi)氵@樣寫就不對
隱藏域也是表單元素,獲取隱藏域hidden的值的方與獲取文本框input的值的方法一樣,也可以用類似的方法動態(tài)設(shè)置隱藏域的值。
1
$("input:hidden").val();
下面給出簡單的示例:
創(chuàng)建Html元素
1
2
3
4
5
6
7
8
div class="box"
span點(diǎn)擊按鈕后獲取隱藏域的值:/span
div class="content"
span偷偷告訴你,隱藏域的值為“我是隱藏域的文本”。/span
input type="hidden" name="test" value="我是隱藏域的文本"
/div
input type="button" value="獲取隱藏域"
/div
設(shè)置css樣式
1
2
3
div.box{width:300px;padding:20px;margin:20px;border:4px dashed #ccc;}
div.box span{color:#999;font-style:italic;}
div.content{width:250px;margin:10px 0;padding:20px;border:2px solid #ff6666;}
編寫jquery代碼
1
2
3
4
5
$(function(){
$("input:button").click(function() {
alert($("input:hidden[name='test']").val());
})
})
觀察效果
1、首先需要新建一個html文檔,可以用任何文本編輯器,這里演示用Dreamweaver軟件,新建并保存html文檔。
2、然后寫html代碼,寫一個input文本輸入框id為inputId,寫一個按鈕,id為buttonId,這里要做的是點(diǎn)擊按鈕就為隱藏域的value賦值。
3、然后把輸入框和按鈕的css樣式寫好,當(dāng)然不寫樣式也可以,這里主要是為了美化一下。
4、最后就是關(guān)鍵步驟了,引入jQuery文件,注意路徑一定要正確,寫jQuery代碼。
5、打開瀏覽器測試一下,點(diǎn)擊按鈕之后輸入框內(nèi)自動輸入了賦值的內(nèi)容。