在asp.net下實現Option條目中填充前置空格的方法

來源:互聯網
上載者:User

在使用Web頁面上的下拉式清單方塊(SELECT element)顯示資料列表時,有時我們會遇到有層次的資料條目。比如論壇中的子論壇和它的分類之間,以及一些具有內含項目關聯性的層次資料條目。使下拉式清單方塊中,不同的level有一定的顯示縮排將是非常友好的一種排版方式。

如果在HTML編寫狀態下,或在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>

如此簡單就實現這個效果了,似乎沒有什麼可說的。可是當我們在ASP.NET中使用伺服器控制項ListBox或DropDownList的時候,要實現這個效果問題就來了。由於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,就是" "。不過在中文的系統中這種方法似乎也說的過去,可是在純英文(Not support East-Asian language)的環境下,這樣的Option條目就暈菜了,錯誤效果如:

// 左圖是在中文系統中,右圖是在純英文系統中

那麼怎麼辦呢?重載ListItem?! 不過此路不通,ListItem類是被sealed修飾的。後來我發現,可以使用 的"原始形式"來讓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>

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.