js點(diǎn)擊文本框彈出可選擇的checkbox復(fù)選框
本文分享一段代碼實(shí)例,它能夠點(diǎn)擊文本框的時(shí)候,能夠彈出下拉的checkbox復(fù)選框,選中復(fù)選框就能夠?qū)⒅祵懭胛谋究蛑校赡茉趯?shí)際應(yīng)用中的效果沒有這么直白簡單,不過可以作為一個(gè)例子演示,以便于學(xué)習(xí)者理解和擴(kuò)展。
代碼如下:
<html>
<head>
<meta charset="gb2312">
<title>js點(diǎn)擊文本框彈出可選擇的checkbox復(fù)選框</title>
<style type="text/css">
#div{
margin-bottom:10px;
position:relative;
}
#div1{
width:153px;
padding-top:0px;
padding-left:0px;
position:absolute;
}
#div1 ul{
margin-top:0px;
padding-left:0px;
background-color:#ccc;
list-style:none;
}
#div1 ul li{
padding-left:0px;
}
#div1 ul li input{
margin-left:15px;
}
.close{
display:none;
}
.open{
display:block;
}
</style>
<script type="text/javascript" src="mytest/jQuery/jquery-1.8.3.js"></script>
<script type="text/javascript">
$(function(){
var position=$("#xx").offset();
$("#div1").offset({
top:position.top+22,
left:position.left
});
$("#xx").click(function(){
$("#NG").toggleClass("open");
});
$("#div1 input[name=ng]").click(function(){
var arr=new Array();
$("input[name=ng]:checked").each(function(key,value){
arr[key]=$(value).val();
});
$("#xx").val(arr.join(","));
})
})
</script>
</head>
<body>
<div id="div">
<div align="center" id="div2" >
<form id="form1">
<input type="text" readonly="readonly" id="xx"/>
<input type="submit" value="查詢"/>
</form>
</div>
<div id="div1">
<ul class="close" id="NG" >
<li><input type="checkbox" name="ng" value=1 />1</li>
<li><input type="checkbox" name="ng" value=2 />2</li>
<li><input type="checkbox" name="ng" value=3 />3</li>
</ul>
</div>
</div>
</body>
</html>
以上代碼實(shí)現(xiàn)了我們的要求,下面介紹一下它的實(shí)現(xiàn)過程。
代碼注釋:
1.$(function(){}),當(dāng)文檔結(jié)構(gòu)完全加載完畢再去執(zhí)行函數(shù)中的代碼。
2.var position=$("#xx").offset(),獲取文本框相對(duì)于document文檔的偏移量,offset()函數(shù)返回的是一個(gè)對(duì)象,此對(duì)象包含兩個(gè)屬性left和top,分別表示相對(duì)于文檔的水平和垂直偏移量。
3.$("#div1").offset({top:position.top+22,left:position.left}),設(shè)置彈出下拉菜單容器的相對(duì)文檔的偏移量,第一個(gè)加22是為了使其在文本框的下面顯示。
4.$("#xx").click(function(){$("#NG").toggleClass("open");}),為文本框注冊(cè)click事件處理函數(shù),點(diǎn)擊它可以切換樣式類open刪除和添加,也就是設(shè)置下拉菜單的顯示和隱藏。
5.$("#div1 input[name=ng]").click(function(){ }),為name屬性值為ng的文本框注冊(cè)click事件處理函數(shù)。
6.var arr=new Array(),創(chuàng)建一個(gè)數(shù)組,用來存放選中checkbox復(fù)選框的value值。
7.$("input[name=ng]:checked").each(function(key,value){arr[key]=$(value).val();}),將選中的復(fù)選框的值存入數(shù)組。
8.$("#xx").val(arr.join(","));,將數(shù)組元素連接成字符串寫入文本框。
希望本文所述對(duì)大家學(xué)習(xí)javascript程序設(shè)計(jì)有所幫助。
相關(guān)文章
關(guān)于onchange事件在IE和FF下的表現(xiàn)及解決方法
本篇文章主要是對(duì)關(guān)于onchange事件在IE和FF下的表現(xiàn)及解決方法進(jìn)行了介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助2014-03-03
使用JavaScript實(shí)現(xiàn)一個(gè)炫酷的羅盤時(shí)鐘
在探究前端動(dòng)畫時(shí),想到之前在鎖屏壁紙看到的羅盤時(shí)鐘,看著很是炫酷,于是說干就干,下面就跟隨小編一起來學(xué)習(xí)一下如何使用JS實(shí)現(xiàn)一個(gè)炫酷的羅盤時(shí)鐘效果吧2024-02-02
擴(kuò)展bootstrap的modal模態(tài)框-動(dòng)態(tài)添加modal框-彈出多個(gè)modal框
這篇文章主要介紹了擴(kuò)展bootstrap的modal模態(tài)框-動(dòng)態(tài)添加modal框-彈出多個(gè)modal框,需要的朋友可以參考下2017-02-02
layerui代碼控制tab選項(xiàng)卡,添加,關(guān)閉的實(shí)例
今天小編就為大家分享一篇layerui代碼控制tab選項(xiàng)卡,添加,關(guān)閉的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-09-09
JavaScript DOM實(shí)現(xiàn)簡單留言板
這篇文章主要為大家詳細(xì)介紹了JavaScript DOM實(shí)現(xiàn)簡單留言板,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01

