一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

asp.net 自制的單選、多選列表實現代碼

問:為什么要“自制”?不是有現成的控件嗎?
答:在ASP.NET的頁面上,ListBox最終是渲染成select元素,而CheckListBox最終被渲染成div或者是table,使得二者的樣式無法統一,或者說要統一很麻煩。
解決:
于是,決定干脆自行組合一些元素,實現單選列表、多選列表的統一樣式。
首先,無論是單選列表還是多選列表,都用一個有邊框的div來做容器:
<div class="list"></div>
然后,在這個div中添加數據項。為了在響應onclick事件時,能夠遍歷數據項,進而做一些樣式上的控制,我需要把各個數據項的name屬性設為一樣的,然后用getElementsByName獲取(這種辦法我在復選框的全選功能上常用)。然而,經過實踐,發現div、span均無name屬性,最終找到用錨點,也就是<a>標記,可以實現。
例如:
復制代碼 代碼如下:
<div id="divDepartments" class="list">
<a name="aDep" style="width:100%" onclick="ItemClicked(this);">部門1</a>
<a name="aDep" style="width:100%" onclick="ItemClicked(this);">部門2</a>
<a name="aDep" style="width:100%" onclick="ItemClicked(this);">部門3</a>
<a name="aDep" style="width:100%" onclick="ItemClicked(this);">部門4</a>
<a name="aDep" style="width:100%" onclick="ItemClicked(this);">部門5</a>
<a name="aDep" style="width:100%" onclick="ItemClicked(this);">部門6</a>
<a name="aDep" style="width:100%" onclick="ItemClicked(this);">部門7</a>
<a name="aDep" style="width:100%" onclick="ItemClicked(this);">部門8</a>
<a name="aDep" style="width:100%" onclick="ItemClicked(this);">部門9</a>
<a name="aDep" style="width:100%" onclick="ItemClicked(this);">部門10</a>
<a name="aDep" style="width:100%" onclick="ItemClicked(this);">部門11</a>
<a name="aDep" style="width:100%" onclick="ItemClicked(this);">部門12</a>
</div>

其中,list樣式:
復制代碼 代碼如下:
.list
{
overflow-y:scroll;
width:120px;
height:150px;
padding:3px;
border:solid 1px #AFAFAF;
background-color: #ffffff;
cursor: pointer;
}

ItemClicked函數用來響應click事件。下面的代碼只是做一些樣式上的變化,還可繼續添加加載數據的內容:
復制代碼 代碼如下:
function ItemClicked(a){
a.style.backgroundColor="#EEEEEE";
as=document.getElementsByName(a.name);
for(i=0;i<as.length;i++){
if(as[i]!=a){as[i].style.backgroundColor="#FFFFFF";}
}
}

帶有復選框的多選列表也大同小異,只是這里由于遍歷數據項時,只要對復選框遍歷即可,故可以使用div做數據項的容器了:
復制代碼 代碼如下:
<div id="divPersons" class="list">
<div><input type="checkbox" />人員1</div>
<div><input type="checkbox" />人員2</div>
<div><input type="checkbox" />人員3</div>
<div><input type="checkbox" />人員4</div>
<div><input type="checkbox" />人員5</div>
<div><input type="checkbox" />人員6</div>
<div><input type="checkbox" />人員7</div>
<div><input type="checkbox" />人員8</div>
<div><input type="checkbox" />人員9</div>
<div><input type="checkbox" />人員10</div>
<div><input type="checkbox" />人員11</div>
</div>

最后,關于數據的加載問題,在當前的具體問題中,我打算用Ajax.Updater,來實現對相應列表的div中數據項的填充。

AspNet技術asp.net 自制的單選、多選列表實現代碼,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 色狠狠色狠狠综合天天 | 国产91在线精品福利 | 久久露脸国产精品 | 91视频麻豆 | 亚洲国产成人欧美激情 | 黄色视屏在线免费观看 | 久久久久国产一级毛片高清片 | 2021国产精品成人免费视频 | 91麻豆精品激情在线观看最新 | 亚洲国产成人久久精品动漫 | 国内第一永久免费福利视频 | 日韩在线一区高清在线 | 中文字幕亚洲一区二区三区 | 91麻豆国产香蕉久久精品 | 91精品福利视频 | 中文字幕综合久久久久 | 国产一区二区在线免费观看 | 国产免费小视频在线观看 | 久久久99精品久久久 | 69国产成人综合久久精品91 | 四虎精品国产一区二区三区 | 38pao强力打造永久免费高清视频 | 日本一区免费看 | 性无遮挡高清视频免费 | 成年ssswww中国女人 | 天天干天天爽 | 一本色道加勒比海在线 | 日韩精品123 | 色噜噜国产在线91蝌蚪 | 亚洲一区精品伊人久久 | 男女视频在线观看免费高清观看 | 久久国产精品国语对白 | 狠狠亚洲婷婷综合色香 | 黄视频网站大全 | 日本一区二区三区在线网 | 综合免费视频 | 欧美日韩国产一区二区三区在线观看 | 99自拍视频在线观看 | 性无遮挡高清视频免费 | 一区二区三区影视 | 日日摸夜夜添夜夜添人人爽 |