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

在asp.net下實現(xiàn)Option條目中填充前導(dǎo)空格的方法

在使用Web頁面上的下拉列表框(SELECT element)顯示數(shù)據(jù)列表時,有時我們會遇到有層次的數(shù)據(jù)條目。比如論壇中的子論壇和它的分類之間,以及一些具有包含關(guān)系的層次數(shù)據(jù)條目。使下拉列表框中,不同的level有一定的顯示縮進將是非常友好的一種排版方式。

    如果在HTML編寫狀態(tài)下,或在ASP等腳本語言中,制作這樣的下拉列表窗口非常容易。我們知道空格" "在Option標簽的前后是會被brower的顯示引擎自動忽略掉的,所以我們使用硬空格 就可以了,效果如下圖:
    Select01.png <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)這個效果了,似乎沒有什么可說的。可是當(dāng)我們在ASP.NET中使用服務(wù)器控件ListBox或DropDownList的時候,要實現(xiàn)這個效果問題就來了。由于ListItem類的Text屬性在輸出為HTML代碼的時候,會自動進行HtmlEncode轉(zhuǎn)換,我們上面的示例會被輸出為
    Select02.png
<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結(jié)果的方法,還有一個也是ugly的方法是使用全角的Space,就是" "。不過在中文的系統(tǒng)中這種方法似乎也說的過去,可是在純英文(Not support East-Asian language)的環(huán)境下,這樣的Option條目就暈菜了,錯誤效果如下圖:
    Select03.png
    // 左圖是在中文系統(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示例效果相同。服務(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下實現(xiàn)Option條目中填充前導(dǎo)空格的方法,轉(zhuǎn)載需保留來源!

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

主站蜘蛛池模板: 91在线视频导航 | 蜜桃视频成a人v在线 | 护士精品一区二区三区 | 国产在线播| 91国内精品久久久久免费影院 | 久草小区二区三区四区网页 | 中文字幕一区二区三 | 免费色播 | 国产一级特黄在线播放 | 精品精品 | 欧美黄色片在线 | 欧美人体大胆私密视频 | 亚洲欧洲高清 | 加勒比视频网站 | 国产高清乱理论片在线看 | 色网站视频 | 丁香五月好婷婷深深爱 | 97成人在线视频 | 天天做.天天爱.天天综合网 | 草草线在成年免费视频网站 | 97国产成人精品免费视频 | 中文字幕久久亚洲一区 | jizz大全日本护士喷奶水 | 人人精品| 狠狠亚洲婷婷综合色香五 | 国产免费福利 | 永久免费观看午夜视频在线 | 色爱五月天 | 激情综合亚洲 | 加勒比精品视频 | 国产视频资源 | 中文字幕在线精品 | 在线播放国产精品 | 99久久国产综合精麻豆 | 成人精品视频一区二区在线 | 伊人久久大香线焦在观看 | 国产成人香蕉在线视频网站 | 日韩精品中文字幕视频一区 | 精品一区二区三区在线观看 | 肉色丝袜一区二区高跟鞋 | 青青热久久国产久精品 |