[精讚] [會員登入]
94249

[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

你可能感興趣的文章

[CKeditor4] 修改特殊字元 CKeditor4 中設定自己想用的特殊字元

[jQuery] checkbox 及 radio 設定值 jQuery 之 checkbox 及 radio 取值及設定值的方法

Jquery+CSS div區塊的拖拉(drag and drop)效果 網頁想要做到拖拉區塊的功能,但又不想使用他人的插件或是 jquery-ui的話,怎麼做?

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

正則表達式:Email名稱防止連續輸入點(.)及下底線(_) Email的名稱中要允許特殊符號,但又不允許連續出現的正則表達式

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

我有話要說

>>

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

訪客留言

[無留言]

隨機好文

使用Google尋找你的手機 這近發現google竟然可以用來找android的手機,而且不需要經過什麼設定或安裝軟體。

談借錢 人借錢時手心向上頭向下,人還錢時手心向下頭向上

世紀帝國征服者新版本--被遺忘的帝國 世紀帝國征服者新版本--被遺忘的帝國 世紀二代的征服者是精典遊戲中的精典,aofe更好玩...

Smarty安裝 smarty 是著名的樣版引擎,非常的好用,用多了突然發現拿掉smarty反而不會寫php了,以下是安裝過程..

設計的工作絕不接受比價 拿買陽春麵的價格想買牛肉麵,寧願倒掉也不賣