在asp.net下實現(xiàn)Option條目中填充前導空格的方法
更新時間:2007年03月08日 00:00:00 作者:
在使用Web頁面上的下拉列表框(SELECT element)顯示數(shù)據(jù)列表時,有時我們會遇到有層次的數(shù)據(jù)條目。比如論壇中的子論壇和它的分類之間,以及一些具有包含關系的層次數(shù)據(jù)條目。使下拉列表框中,不同的level有一定的顯示縮進將是非常友好的一種排版方式。
如果在HTML編寫狀態(tài)下,或在ASP等腳本語言中,制作這樣的下拉列表窗口非常容易。我們知道空格" "在Option標簽的前后是會被brower的顯示引擎自動忽略掉的,所以我們使用硬空格 就可以了,效果如下圖:
<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>
如此簡單就實現(xiàn)這個效果了,似乎沒有什么可說的。可是當我們在ASP.NET中使用服務器控件ListBox或DropDownList的時候,要實現(xiàn)這個效果問題就來了
。由于ListItem類的Text屬性在輸出為HTML代碼的時候,會自動進行HtmlEncode轉換,我們上面的示例會被輸出為
:

<select>
<option value="0">Level 00</option>
<option value="1">&nbsp;Level 01</option>
<option value="2">&nbsp;&nbsp;Level 02</option>
<option value="3">&nbsp;&nbsp;&nbsp;Level 03</option>
<option value="4">&nbsp;&nbsp;&nbsp;&nbsp;Level 04</option>
</select>
真是讓人郁悶,我第一次遇到這個問題時,使用了一個很ugly的方法來解決。就是重載控件,在Render的時候把"&nbsp;"變回為" "。大概就是:
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("&nbsp;", " ");
writer.Write(strb.ToString());
}
}
這個解決方案問題很多,效率是一回事,并且非常不完備。除了使用這種"野蠻"的修改Render結果的方法,還有一個也是ugly的方法是使用全角的Space,就是" "。不過在中文的系統(tǒng)中這種方法似乎也說的過去,可是在純英文(Not support East-Asian language)的環(huán)境下,這樣的Option條目就暈菜了,錯誤效果如下圖:

// 左圖是在中文系統(tǒng)中,右圖是在純英文系統(tǒng)中
那么怎么辦呢?重載ListItem?! 不過此路不通,ListItem類是被sealed修飾的
。后來我發(fā)現(xiàn),可以使用 的"原始形式"來讓DropListBox輸出正確的HTML代碼。什么是 的原始形式呢? 這個東西本來是在RFC 1866中定義的named entity,全稱叫做:no-break space,CDATA格式為: 。我們把160作為字符放入ListItem的Text中,就能得到正確的HTML輸出,效果和第一幅圖中的HTML示例效果相同。服務器端代碼為:
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>
如果在HTML編寫狀態(tài)下,或在ASP等腳本語言中,制作這樣的下拉列表窗口非常容易。我們知道空格" "在Option標簽的前后是會被brower的顯示引擎自動忽略掉的,所以我們使用硬空格 就可以了,效果如下圖:
<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>如此簡單就實現(xiàn)這個效果了,似乎沒有什么可說的。可是當我們在ASP.NET中使用服務器控件ListBox或DropDownList的時候,要實現(xiàn)這個效果問題就來了

<select>
<option value="0">Level 00</option>
<option value="1">&nbsp;Level 01</option>
<option value="2">&nbsp;&nbsp;Level 02</option>
<option value="3">&nbsp;&nbsp;&nbsp;Level 03</option>
<option value="4">&nbsp;&nbsp;&nbsp;&nbsp;Level 04</option>
</select>真是讓人郁悶,我第一次遇到這個問題時,使用了一個很ugly的方法來解決。就是重載控件,在Render的時候把"&nbsp;"變回為" "。大概就是:
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("&nbsp;", " ");
writer.Write(strb.ToString());
}
}這個解決方案問題很多,效率是一回事,并且非常不完備。除了使用這種"野蠻"的修改Render結果的方法,還有一個也是ugly的方法是使用全角的Space,就是" "。不過在中文的系統(tǒng)中這種方法似乎也說的過去,可是在純英文(Not support East-Asian language)的環(huán)境下,這樣的Option條目就暈菜了,錯誤效果如下圖:

// 左圖是在中文系統(tǒng)中,右圖是在純英文系統(tǒng)中
那么怎么辦呢?重載ListItem?! 不過此路不通,ListItem類是被sealed修飾的
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>相關文章
ASP.NET中上傳并讀取Excel文件數(shù)據(jù)示例
如何打開Excel數(shù)據(jù)庫文件,想必有很多朋友都不清楚吧,下面通過一個簡單的例子,實現(xiàn)讀取Excel數(shù)據(jù)文件2014-05-05
.Net中關于stirng轉System.Type的一種實現(xiàn)思路詳解
這篇文章主要給大家介紹了.Net中關于stirng轉System.Type的一種實現(xiàn)思路的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-05-05
.NET讀寫Excel工具Spire.Xls使用 Excel文件的控制(2)
這篇文章主要為大家詳細介紹了.NET讀寫Excel工具Spire.Xls使用,Excel文件的控制,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-11-11
asp.net Repeater控件的說明及詳細介紹及使用方法
Repeater控件是Web 服務器控件中的一個容器控件,它使您可以從頁的任何可用數(shù)據(jù)中創(chuàng)建出自定義列表。2010-04-04

