1. 程式人生 > >JQuery獲取標籤內容

JQuery獲取標籤內容

1、先講講JQuery的概念 

JQuery首先是由一個 America 的叫什麼 John Resig的人建立的,後來又很多的JS高手也加入了這個團隊。其實 JQuery是一個JavaScript的類庫,這個類庫集合了很多功能方法,利用類庫你可以用簡單的一些程式碼實現一些複雜的JS效果。 
2、JQuery實現了 程式碼的分離 
不用再網頁中加入如:onclick之類的事件來呼叫函數了,直接引入JQuery類庫和自己編寫的JQuery程式碼就可以了; 
如: 
$(function(){ 
   $("Element").click{function(){ 
          alert("點選我哦!"); 

     } 
   } 
}); 
上面的程式碼中 只要定義了Element 這個元素  後面的click是動作 

alert("點選我哦!");這個是要執行的程式碼,當然你可以有很多的操作在這個函式中; 
這裡面的$這個號代表JQuery的意思 ,就是引用類庫了。。。我是這麼理解的; 
3、JQuery的核心的一些方法 
each(callback) '就像迴圈 
$("Element").length; ‘元素的個數,是個屬性 
$("Element").size(); ’也是元素的個數,不過帶括號是個方法 
$("Element").get(); ‘某個元素在頁面中的集合,以陣列的形式儲存 
$("Element").get(index); ’功能和上面的相同,index表示第幾個元素,陣列的下標 

$("Element").get().reverse(); ‘把得到的陣列方向 
$("Element1").index($("Element2")); ’元素2在元素1中的索引值是。。。 
4、基本物件獲取(注意這裡獲取的都是Jquery物件而不是Dom物件哦,但是他倆是可以轉換滴) 
$("*")  ‘表示獲取所有物件   但是我至今沒這樣用過 
$("#XXX") ’獲得 id=XXX 的元素物件(id可以是標籤的id或CSS樣式id) 常用 

$("input[name='username']")   獲得input標籤中name='userName'的元素物件 常用 

$(".abc") ' 獲得樣式class的名字是.abc的元素物件  常用 

$("div") ' 標籤選擇器 選擇所有的div元素  常用 
$("#a,.b,span") '表示獲得ID是a的元素和使用了類樣式b的元素以及所有的span元素 
$("#a .b p") 'ID號是a的並且使用了 b樣式的 所有的p元素 

示例: 

<html> 
    <head> 
        <title>jquery測試</title> 
        <meta http-equiv="content-type" content="text/html; charset=UTF-8"> 
        <script type="text/javascript" src="../js/jquery-1.4.1.js"></script> 
        <style type="text/css"> 
        .checkCss{ 
            color:blue; 
        } 
        .redioCss{ 
            color:red; 
        } 
        </style> 
        <script type="text/javascript"> 
            $(function(){ 
                // $("#XXX") 獲得id=XXX的所有Jquery物件 
                $("#subt").click(function(){ 
                    // $("XXX") 獲得XXX標籤名的所有Jquery物件 
                    alert("input 標籤的物件個數為:"+$("input").length); 
                    // $("XXX[name='YYY']") 獲得XXX標籤名下name='YYY'的所有Jquery物件 
                    // val()獲得屬性值 
                    alert("name='userName'的輸入框內容為:"+$("input[name='userName']").val()); 
                    // 注意獲得value值的第二種方式 
                    alert("name='note'的輸入框內容為:"+$("input[name='note']").attr("value")); 
                    alert("下拉選單被選中項的文字為:"+$("#sex option:selected").text()); 
                    alert("下拉選單被選中項的值為:"+$("#sex").val()); 
                    alert("複選框選中的個數為:"+$("input[name='check']:checked").length); 
                    if($("input[name='check']:checked").length>0){ 
                        var allCheckValue=""; 
                        var allCheckText=""; 
                        $("input[name='check']:checked").each(function(){ 
                            allCheckValue+=$(this).val()+" "; 
                            allCheckText+=$(this).parent(".checkCss").text()+" "; 
                        }); 
                        alert("複選框選中的文字為:"+allCheckText+" 值為:"+allCheckValue); 
                    } 
                    if($("input[name='status']:checked").length>0){ 
                        alert("單選框選中的文字為:"+$("input[name='status']:checked").parent(".redioCss").text()+" 值為:"+$("input[name='status']:checked").val()); 
                    } 
                }); 
            }); 
            </script> 
    </head> 

    <body> 
        姓名:<input type="text" name="userName" width="250"><br> 
        性別:<select id="sex" name="userSex" style="width: 155"> 
                <option value="1">男</option> 
                <option value="2">女</option> 
                <option value="3">不男不女</option> 
             </select><br> 
        愛好:<span class="checkCss"><input type="checkbox" name="check" value="1">旅遊</span> 
             <span class="checkCss"><input type="checkbox" name="check" value="2">音樂</span><br> 
             &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 
             <span class="checkCss"><input type="checkbox" name="check" value="3">體育</span> 
             <span class="checkCss"><input type="checkbox" name="check" value="4">文學</span><br> 
        狀態:<span class="redioCss"><input type="radio" name="status" value="1">在職</span> 
             <span class="redioCss"><input type="radio" name="status" value="2">離職</span><br> 
        簡介:<input type="text" name="note" width="250"><br> 
        <input type="button" value="提交" id="subt"><br> 
    </body> 
</html> 

5、層級元素獲取 
$("Element1 Element2 Element3 ....")  '前面父級 後面是子集 
$("div > p") '獲取div下面的所有的 p元素 
$("div + p") 'div元素後面的第一個 p元素 
$("div ~ p") 'div後面的所有的 p元素 
6、簡單物件獲取 
$("Element:first") 'HTML頁面中某類元素的第一個元素 
$("Element:last") 'HTML頁面中某類元素的最後一個元素 
$("Element:not(selector)") '去除所有與給定選擇器匹配的元素,如:$("input:not(:checked)") 表示選擇所有沒有選中的複選框 
$("Element:even") '獲得偶數行 
$("Element:odd“)'獲得奇數行 
$("Element:eq(index)")  '取得一個給定的索引值 
$("Element:gt(index)")  '取得給定索引值的元素  之後的所有元素 
$("Element:lt(index)")  '取得給定索引值的元素  之前的所有元素 
。。。 
7、內容物件的獲取和物件可見性 
$("Element:contains(text)") '元素中是否包含text文字內容 
$('Element:empty") '獲得元素不包含子元素或文字的 
$("Element:partnt") '獲得元素包含子元素或文字的 
$("Element:has(selector)") ‘是否包含某個元素, 如:$("p:has(span)")表示所有包含span元素的p元素 
$("Element:hidden") '選擇所有可見元素 
$("Element:visible") '選擇所有不可見元素 
8、其他物件獲取方法 
$("Element[id]") '所有帶有ID屬性的元素 
$("Element[attribute = youlika ]" '獲得所有某個屬性為youlika的元素 
$("Element[attribute != youlika ]" '獲得所有某個屬性為不是youlika的元素 
$("Element[attribute ^= youlika ]" '獲得所有某個屬性為不是youlika的開頭的元素 
$("Element[attribute $= youlika ]" '獲得所有某個屬性為不是youlika的結尾的元素 
$("Element[attribute *= youlika ]" '獲得所有某個屬性包含youlika的開頭的元素 
$("Element[selector1][selector2][....]") ’符合屬性選擇器,比如$("input[id][name][value=youlika ]")表示獲得帶有ID、Name以及value是youlika 的input元素。 
9、子元素的獲取 
$("Element:nth-child(index)") '選擇父級下面的第n個元素 
$("Element:nth-child(even)") '選擇父級下面的偶數 
$("Element:nth-child(odd)") '選擇父級下面的奇數 
$("Element:nth-child(3n+1)") '表示式 
$("Element:first-child") '選擇父級下面的第一個子元素 
$("Element:last-child") '選擇父級下面的最後一個子元素 
$("Element:only-child") '匹配父級下的唯一的一個子級元素,例如dt在dl列表中唯一,那麼將選擇dt 
10、表單物件獲取 
$(:input)//查詢所有的Input元素,當然也包括下拉列表,文字域,單選框,複選框等。 
$(:text)//匹配所有的單行文字框 
$(:password)//匹配所有的密碼框 
$(:radio)//匹配所有的單選按鈕 
$(:checkbox)//匹配所有的複選框 
$(:submit)//匹配所有的提交按鈕 
$(:image)//匹配所有的影象域,例如<input type="image" /> 
$(:reset)//匹配所有的重置按鈕 
$(:button)//匹配所有的按鈕 
$(:file)//匹配所有的檔案上傳域 
$(:hidden)//匹配所有的不可見元素或者type為hidden的元素 
$(:enabled)//匹配所有可用的input元素,比如radio:enabled表示匹配所有可用的單選按鈕 
$(:disabled)//匹配所有的不可用input元素,作用與上相反 
$(:checked)//匹配所有選中的複選框元素 
$(:selected)//匹配所有的下拉列表 
11、元素屬性的設定與移除 
$("Element").attr(name) '取得第一個匹配的屬性值,比如$("img").attr("src") 
$("Element".attr(key,value)") '某一個元素設定屬性 
$("Element".attr({key:value,key1:value,....})) ‘為某個元素一次性設定多個屬性 
$("Element").attr(key,function) '為所有匹配的元素設定一個計算的屬性值。 
$("Element").removeAttr(name)//移除某一個屬性