[精讚] [會員登入]
14449

[jQuery] checkbox 及 radio 設定值

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

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

分享連結 [jQuery] checkbox 及 radio 設定值@新精讚
(文章歡迎轉載,務必尊重版權註明連結來源)
2022-04-16 01:55:37 最後編修
2016-12-05 10:15:08 By 張○○
 

自動目錄

這篇是精華,知道的人可以省你很多寶貴的時間

網路上如果搜尋 jquery radio / checkbox 取值,似乎找到的方法都不能用。以下是我試過失敗的寫法:

if($("#chk1").attr('checked')==undefined); <== X 不成功 checkbox 取值失敗
var item = $('input[@name=items][@checked]').val(); <== X 不成功 radio取值失敗,這樣會取出第一筆,無論筆是否有被選
$("input[@type=radio][@checked]").val(); <==也是失敗

checkbox 設定值

$("#chk1").attr("checked",''); //設定不打勾

$("#chk2").attr("checked",true); //設定打勾

$("#chk3").attr("checked",1); //設定打勾

Javascript

  如果變數本身(假設是this)是checkbox,

     this.checked = true;

checkbox 取值

var v=$("input[name='fetion']").is(":checked");

v="true"有被打勾,否則為 "false"

注意:使用 is 的方法得到的會是字串的 "true"/"false",而不是布林值。所以當你用 if(v) 這種方式來判斷的話,永遠為真

或是

var v=$("#fetion").is(":checked");

var v= (typeof($("input[name=_dis]:checked").val()) == "undefined" )? "0":"1";

直接用三元運算子得到 v值為0或1。

  Javascript

  如果this本身是checkbox
  那麼直接取值即可 this.checked 結果會是true/false

radio 賦值

$('input[name="sex"]')[1].checked = true; //radio 賦值==>第二個選項選取

$("input[name=state][value='2']").attr('checked',true); //radio 賦值==>值為2的那個選取

順便一提的,如果一個頁面有很多<input name="xxx" .... /> 的欄位,如果每個設定 id 再賦值顯然太累了,不如一行解決。

$("input[name=xxx]").val( 值 );

radio 取值

以下範例示範當使用者按下 submit ( id=sb1 ) 時的檢查動作,其中 radio 的 name=doway

$("#sb1").click(function(){
   var method =$("input[name='doway']:checked").val(); //radio 取值,注意寫法
   if( typeof(method) == "undefined"){    // 注意檢查完全沒有選取的寫法,這行是精華
   alert( "請選取操作方式!");
   return false;
}


原文 2009-10-24 22:13:02

END

你可能感興趣的文章

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

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

[jQuery] textarea 的取值和給值 HTML 的 TEXTAREA 標籤若要用 jquery 取值,不能使用 .text() 或 .html() ,使用 .

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

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

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

隨機好文

HP SAS硬碟leds燈號說明 HP SAS硬碟leds燈號(hp g7/g6系統適用)說明

[Win7] 燒錄 iso 檔 在Windows7 中內建燒錄程式,可以直接把檔案拉到光碟機裡,再執行燒錄。

一個邏輯的錯誤刪了全部檔案的經驗 今天本來想做一件很簡單的事,但卻足足浪費我多一倍的時間,再加上刪掉我全部的檔案,原因只是因為我自己的邏輯錯誤。

[PHP] 檢查IP是否在某個網段內 mtachcidr 要檢查IP是否在某個網段內,要寫幾行?10行?5行? 不用,只要2行。以下是我寫的 code /** * matchCI

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