[精讚] [會員登入]
95304

[jQuery] select 元件的取值及給值

html中的元件select,在jquery中要如何使用?

分享此文連結 //n.sfs.tw/10047

分享連結 [jQuery] select 元件的取值及給值@新精讚
(文章歡迎轉載,務必尊重版權註明連結來源)
2019-11-12 21:45:09 最後編修
2016-10-18 20:43:08 By 張○○
 

自動目錄

html中的元件select,在jquery中要如何使用?

<select id="sfs" name="sfsname">
  <option value="1">第一項</option>
  <option value="2">第二項</option>
  <option value="3">第三項</option>
</select>

設定值

  $("#sfs")[0].selectedIndex = 0;   //設定第一個欄位選取,[0]一定要加

  $("#sfs")[0].selectedIndex = 1; //設定第二個選項選取則指定為1,以此類推。

  $("#sfs").val(3);  //設定值為3的選項被選取

取值

  var s= $("#sfs").val();

以name的屬性取得select物件
  var s=$("select[name='sfsname']").val();

取得選取值的文字 取得選取值的文字而非其值
  var txt=$("#sfs :selected").text();

取得第1個選項
  $("#sfs option:first").css("color","red");

取回選中的選項,取得選中的選項給定顏色紅色字
  $("#sfs option:selected").css("color","red");

未選取的 select 判斷

利用null來決定一個select是否為未選取
  if( $("#sfs").val() == null){ alert("null"); }

取回最大索引值(index)

select 中的 最大索引值就是選項數目+1,也可以-1來判斷所有的項目個數。

var maxIndex=$("#sfs option:last").attr("index");

如果是用觸發回傳的select,例如階層式選取區域ajax方法取回的select,選取指定select id也沒有用,這時只能由$(this)來下手:
maxIndex=$(this).children("option:last").attr('index');

在前後加入選項

  $("#sfs").prepend(new Option('加一個選項在最前面,值為0,選取', 0, true));
  $("#sfs").append(new Option('加一個選項在最後面,值為1,不選取', 1, false));

清空所有選項

  $("#sfs").empty();

使用AJAX的JSON 方法取回資料庫的資料

若想在change 事件時,會用 AJAX的JSON格式取回資料,做法如下:

HTML

<select id="sfs" name="sfsname"> 
  <option value="1">第一項</option>
  <option value="2">第二項</option>
  <option value="3">第三項</option>
</select>
<!-- 先隱藏子層select元件 -->
<select id="sfs2" name="sfsname2" style="display:none;"> 
</select>

jQuery

$("#sfs").change(function(){;
  // 這裡的 provider.php 是自己撰寫的php碼,作用是自資料庫取得資料後回傳(印)一個 json格式的資料,p參數代入選單目前的值
  // 例如格式:
   $.getJSON('provider.php?p='+ $("#sfs").val(), 
  // data是json格式的資料,把這個資料寫入表單中
   function(data){
     $("#sfs2").css("display","inline"); //顯現
     ..加入選項..
   });
});

待完..


原文張貼於 2009-10-18 04:59:48 2014-11-23改寫 新精讚再次改寫

END

你可能感興趣的文章

[jQuery] 利用load()來達成ajax的寫法 jQuery中利用load()來達成ajax的寫法,也有人稱他是假的ajax,作法就是..

[CKeditor4] 設定區塊樣式、段落格式、字型名稱及字型大小 CKeditor4中要自訂設定區塊樣式、段落格式、字型名稱及字型大小。

[Ckeditor4] 讀、寫與插入內容到欄位 Ckeditor4 提供非常多方法,可以插入、讀取和寫入到TEXTAREA中

[Vue3.js] vue3 運行時出現 Network: unavailable 的解決方法 vue3 運行測試平台時如果需要遠端連線的話怎麼辦?

[Javascript] 偵錯方式 (火狐中的javascript偵錯) javascript 並不是很容易偵錯(debug)的語言,但那是以前,現在有很多瀏覽器支持很多的工具,此文以火狐為例談談偵錯...

[CKeditor4] 修改調色盤 修改ckeditor預設的調色盤

我有話要說

>>

限制:留言最高字數1000字。 限制:未登入訪客,每則留言間隔需超過10分鐘,每日最多5則留言。

訪客留言

[無留言]

隨機好文

為什麼要買長達二十年的保單? 為什麼要買長達二十年的保單?找一個可以說服我買二十年保單的理由。

精讚的版面變化 ▓此文僅作為舊文的記錄▓ 這篇文章為了紀念改版完成而撰寫。 原本的部落格是民國97年的作品,那時還是用舊有的技術來寫,很

詭異的創業思維 創業的思維中,有多少銀彈,有多少技術,有多少人脈,有多少時間等等,每個都要考慮進去,以熱忱建立的關係脆弱的像蘇打餅乾一樣..

「許功蓋」的字以及源由 有玩過電腦一段時間的人,都聽過這個人(有一天我才發現7年級的竟然都不認識這個

[AS3] 物件加上超連結的方法 物件加上超連結,可讓使用者點擊的方法