您好,登錄后才能下訂單哦!
這篇文章運用簡單易懂的例子給大家介紹select在jquery中的應(yīng)用,代碼非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
select(),這個函數(shù)用于確定一個或多個套接口的狀態(tài),對每一個套接口,調(diào)用者可查詢它的可讀性、可寫性及錯誤狀態(tài)信息,用fd_set結(jié)構(gòu)來表示一組等待檢查的套接口,在調(diào)用返回時,這個結(jié)構(gòu)存有滿足一定條件的套接口組的子集,并且select()返回滿足條件的套接口的數(shù)目。
觸發(fā)每一個匹配元素的select事件
這個函數(shù)會調(diào)用執(zhí)行綁定到select事件的所有函數(shù),包括瀏覽器的默認(rèn)行為??梢酝ㄟ^在某個綁定的函數(shù)中返回false來防止觸發(fā)瀏覽器的默認(rèn)行為。
一、基礎(chǔ)取值問題
例如<select class="selector"></select>
1、設(shè)置value為pxx的項選中
$(".selector").val("pxx");
2、設(shè)置text為pxx的項選中
$(".selector").find("option:contains('pxx')").attr("selected",true);
注意:之前$(".selector").find("option[text='pxx']").attr("selected",true);
這種寫法是錯誤的,目前個人證實input支持這種獲取屬性值的寫法:"input[text='pxx']
",select中需要"option:contains('pxx')
"這樣獲取。
這里有一個中括號的用法,中括號里的等號的前面是屬性名稱,不用加引號。很多時候,中括號的運用可以使得邏輯變得很簡單。
3、獲取當(dāng)前選中項的value
$(".selector").val();
4、獲取當(dāng)前選中項的text
$(".selector").find("option:selected").text();
這里用到了冒號,掌握它的用法并舉一反三也會讓代碼變得簡潔。
二、很多時候用到select的級聯(lián),即第二個select的值隨著第一個select選中的值變化。這在jquery中是非常簡單的。
如:
$(".selector1").change(function(){ // 先清空第二個 $(".selector2").empty(); // 實際的應(yīng)用中,這里的option一般都是用循環(huán)生成多個了 var option = $("<option>").val(1).text("pxx"); $(".selector2").append(option); });
三、jQuery獲取Select選擇的Text和Value:
語法解釋:
$("#select_id").change(function(){//code...}); //為Select添加事件,當(dāng)選擇其中一項時觸發(fā) var checkText=$("#select_id").find("option:selected").text(); //獲取Select選擇的Text var checkValue=$("#select_id").val(); //獲取Select選擇的Value var checkIndex=$("#select_id ").get(0).selectedIndex; //獲取Select選擇的索引值 var maxIndex=$("#select_id option:last").attr("index"); //獲取Select最大的索引值
四、jQuery設(shè)置Select選擇的 Text和Value:
語法解釋:
$("#select_id ").get(0).selectedIndex=1; //設(shè)置Select索引值為1的項選中 $("#select_id ").val(4); // 設(shè)置Select的Value值為4的項選中 $("#select_id option[text='jQuery']").attr("selected", true); //設(shè)置Select的Text值為jQuery的項選中
五、jQuery添加/刪除Select的Option項:
語法解釋:
$("#select_id").append("<option value='Value'>Text</option>"); //為Select追加一個Option(下拉項) $("#select_id").prepend("<option value='0'>請選擇</option>"); //為Select插入一個Option(第一個位置) $("#select_id option:last").remove(); //刪除Select中索引值最大Option(最后一個) $("#select_id option[index='0']").remove(); //刪除Select中索引值為0的Option(第一個) $("#select_id option[value='3']").remove(); //刪除Select中Value='3'的Option $("#select_id option[text='4']").remove(); //刪除Select中Text='4'的Option
六、jquery radio取值,checkbox取值,select取值,radio選中,checkbox選中,select選中,及其相關(guān)
1 獲取一組radio被選中項的值
var item = $('input[name=items][checked]').val();
2 獲取select被選中項的文本
var item = $("select[name=items] option[selected]").text();
3 select下拉框的第二個元素為當(dāng)前選中值
$('#select_id')[0].selectedIndex = 1;
4 radio單選組的第二個元素為當(dāng)前選中值
$('input[name=items]').get(1).checked = true;
七、獲取值:
文本框,文本區(qū)域:$("#txt").attr("value");
多選框 checkbox:$("#checkbox_id").attr("value");
單選組radio: $("input[type=radio][checked]").val();
下拉框select: $('#sel').val();
八、控制表單元素:
文本框,文本區(qū)域:
$("#txt").attr("value",'');//清空內(nèi)容 $("#txt").attr("value",'11');//填充內(nèi)容
多選框checkbox:
$("#chk1").attr("checked",'');//不打勾 $("#chk2").attr("checked",true);//打勾 if($("#chk1").attr('checked')==undefined) //判斷是否已經(jīng)打勾
單選組 radio:
$("input[type=radio]").attr("checked",'2');//設(shè)置value=2的項目為當(dāng)前選中項
下拉框 select:
$("#sel").attr("value",'-sel3');//設(shè)置value=-sel3的項目為當(dāng)前選中項 $("<option value='1'>1111</option><option value='2'>2222</option>").appendTo("#sel")//添加下拉框的option $("#sel").empty();//清空下拉框
九、判斷在select 是否存在某個value 的 option:
function is_Exists(selectid,value){ var theid='#'+selectid; var count=$(theid).get(0).options.length; var isExist = false; for(var i=0;i<count;i++){ if ($(theid).get(0).options[i].value == value){ isExist=true; break; } } return isExist; }
關(guān)于select在jquery中的應(yīng)用就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。