在使用Web頁(yè)面上的下拉列表框(SELECT element)顯示數(shù)據(jù)列表時(shí),有時(shí)我們會(huì)遇到有層次的數(shù)據(jù)條目。比如論壇中的子論壇和它的分類之間,以及一些具有包含關(guān)系的層次數(shù)據(jù)條目。使下拉列表框中,不同的level有一定的顯示縮進(jìn)將是非常友好的一種排版方式。
如果在HTML編寫狀態(tài)下,或在ASP等腳本語(yǔ)言中,制作這樣的下拉列表窗口非常容易。我們知道空格" "在Option標(biāo)簽的前后是會(huì)被brower的顯示引擎自動(dòng)忽略掉的,所以我們使用硬空格 就可以了,效果如下圖:
<select>
<option value="0">Level 00</option>
<option value="1"> Level 01</option>
<option value="2"> Level 02</option>
<option value="3"> Level 03</option>
<option value="4"> Level 04</option>
</select>
如此簡(jiǎn)單就實(shí)現(xiàn)這個(gè)效果了,似乎沒有什么可說(shuō)的。可是當(dāng)我們?cè)?a href=/itjie/ASPjishu/ target=_blank class=infotextkey>ASP.NET中使用服務(wù)器控件ListBox或DropDownList的時(shí)候,要實(shí)現(xiàn)這個(gè)效果問題就來(lái)了
。由于ListItem類的Text屬性在輸出為HTML代碼的時(shí)候,會(huì)自動(dòng)進(jìn)行HtmlEncode轉(zhuǎn)換,我們上面的示例會(huì)被輸出為
:

<select>
<option value="0">Level 00</option>
<option value="1"> Level 01</option>
<option value="2"> Level 02</option>
<option value="3"> Level 03</option>
<option value="4"> Level 04</option>
</select>
真是讓人郁悶,我第一次遇到這個(gè)問題時(shí),使用了一個(gè)很ugly的方法來(lái)解決。就是重載控件,在Render的時(shí)候把" "變回為" "。大概就是:
class XxxDropDownList : DropDownList


{
protected override void Render(HtmlTextWriter writer)

{
StringBuilder strb = new StringBuilder();
StringWriter sw = new StringWriter(strb);
HtmlTextWriter htw = new HtmlTextWriter(sw);
base.Render(htw);
strb.Replace(" ", " ");
writer.Write(strb.ToString());
}
}
這個(gè)解決方案問題很多,效率是一回事,并且非常不完備。除了使用這種"野蠻"的修改Render結(jié)果的方法,還有一個(gè)也是ugly的方法是使用全角的Space,就是" "。不過在中文的系統(tǒng)中這種方法似乎也說(shuō)的過去,可是在純英文(Not support East-Asian language)的環(huán)境下,這樣的Option條目就暈菜了,錯(cuò)誤效果如下圖:

// 左圖是在中文系統(tǒng)中,右圖是在純英文系統(tǒng)中
那么怎么辦呢?重載ListItem?! 不過此路不通,ListItem類是被sealed修飾的
。后來(lái)我發(fā)現(xiàn),可以使用 的"原始形式"來(lái)讓DropListBox輸出正確的HTML代碼。什么是 的原始形式呢? 這個(gè)東西本來(lái)是在RFC 1866中定義的named entity,全稱叫做:no-break space,CDATA格式為: 。我們把160作為字符放入ListItem的Text中,就能得到正確的HTML輸出,效果和第一幅圖中的HTML示例效果相同。服務(wù)器端代碼為:
char nbsp = (char)0xA0;
for ( int i=0 ; i < 5 ; ++i )


{
ddl3.Items.Add(new ListItem("Level 0".PadLeft(i+7, nbsp) + i, i.ToString()));
}

生成的客戶端代碼為:
<select>
<option value="0">Level 00</option>
<option value="1"> Level 01</option>
<option value="2"> Level 02</option>
<option value="3"> Level 03</option>
<option value="4"> Level 04</option>
</select>
AspNet技術(shù):在asp.net下實(shí)現(xiàn)Option條目中填充前導(dǎo)空格的方法,轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。