jQuery的屬性與樣式之.val()

來源:互聯網
上載者:User

標籤:匹配   ring   函數   body   cli   唯讀   多個   htm   第一個   

jQuery中有一個.val()方法主要是用於處理表單元素的值,比如 input, select 和 textarea。

.val()方法

  1. .val()無參數,擷取匹配的元素集合中第一個元素的當前值
  2. .val( value ),設定匹配的元素集合中每個元素的值
  3. .val( function ) ,一個用來返回設定值的函數

 注意事項:

  1. 通過.val()處理select元素, 當沒有選擇項被選中,它返回null
  2. .val()方法多用來設定表單的欄位的值
  3. 如果select元素有multiple(多選)屬性,並且至少一個選擇項被選中, .val()方法返回一個數組,這個數組包含每個選中選擇項的值

 

.html(),.text()和.val()的差異總結:  

  1. .html(),.text(),.val()三種方法都是用來讀取選定元素的內容;只不過.html()是用來讀取元素的html內容(包括html標籤),.text()用來讀取元素的純文字內容,包括其後代元素,.val()是用來讀取表單元素的"value"值。其中.html()和.text()方法不能使用在表單元素上,而.val()只能使用在表單元素上;另外.html()方法使用在多個元素上時,唯讀取第一個元素;.val()方法和.html()相同,如果其應用在多個元素上時,只能讀取第一個表單元素的"value"值,但是.text()和他們不一樣,如果.text()應用在多個元素上時,將會讀取所有選中元素的常值內容。
  2. .html(htmlString),.text(textString)和.val(value)三種方法都是用來替換選中元素的內容,如果三個方法同時運用在多個元素上時,那麼將會替換所有選中元素的內容。
  3. .html(),.text(),.val()都可以使用回呼函數的傳回值來動態改變多個元素的內容。
<!DOCTYPE html><html><head>    <meta http-equiv="Content-type" content="text/html; charset=utf-8" />    <title></title>    <style>    p {        color: red;        margin: 4px;    }        b {        color: blue;    }    </style>    <script src="http://libs.baidu.com/jquery/1.9.1/jquery.js"></script></head><body>    <h3>.val()</h3>        <select id="single">        <option>慕課網</option>        <option>部落格園</option>    </select>    <select id="multiple" multiple="multiple">        <option selected="selected">imocc</option>        <option>慕課網</option>        <option selected="selected">部落格園</option>    </select>    <input type="text" value="click a button" />    <p></p>    <script type="text/javascript">        //單個select,返回第一個        $("p").text( $("#single").val())    </script>    <script type="text/javascript">        //多個select被選擇,返回["imocc", "部落格園"]        $("p").text( $("#multiple").val() )     </script>    <script type="text/javascript">        //選擇一個表單,修改value的值        $("input[type=‘text‘]").val(‘修改表單的欄位‘)     </script></body></html>

 

jQuery的屬性與樣式之.val()

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.