重写RadioButtonList服务器控件的RenderItem方法,隐藏radio元素

本文介绍如何重写RadioButtonList服务器控件的RenderItem方法,通过判断浏览器类型来实现对radio元素的隐藏。在IE和非IE浏览器中,分别通过设置样式width:0px;height:0px或display:none达到隐藏效果。实验证实在Firefox和Internet Explorer浏览器上,隐藏后的radio元素不影响带有CSS的label标签显示,同时保持AutoPostBack=true时的正常回调功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

思路:先判断浏览器是否为IE浏览器,如果是IE浏览器就将radio元素样式为width:0px;height:0px;若不是IE浏览器就将radio元素的样式设置为display:none。

//注释掉原来的RenderItem方法
//base.RenderItem(itemType, repeatIndex, repeatInfo, writer);
bool isIE = HttpContext.Current.Request.UserAgent.ToLower().IndexOf("msie") > 0;
ListItem li = Items[repeatIndex];
//回调函数的eventTarget
string name = this.ClientID.Replace('_','$')+"$"+repeatIndex.ToString();
//用于radio元素的name属性
string pname = this.ClientID.Replace('_','$');
//用于radio元素的id属性及label标签的for属性
string id = this.ClientID + "_" + repeatIndex.ToString();
//定义当AutoPostBack=true时的回调
string onclick = AutoPostBack?"onclick=\"javascript:setTimeout(\'__doPostBack(\\'"+name+"\\',\\'"+li.Value+"\\')\',0)\"":"";
//SelectedCssClass和ItemCssClass是我增加的两个Css,分别用于选中项的label和未选中项的label标签的class。
string css = li.Selected ? SelectedCssClass : ItemCssClass;
//可以在标签外围增加新标签,如<div style=''>{0}{1}</div>
string div = "{0}{1}";
//若为IE浏览器style=width:0px;height:0px; 其他浏览器style=display:none;
string radio = "<input type='radio' id='"+id+"' name='"+pname+"' value='"+li.Value+"'"+onclick+" style='"+(isIE?"width:0px;height:0px;":"display:none;")+"'/>";
string label = "<label for='"+id+"' class='"+css+"'>"+li.Text+"</label>";
writer.Write(string.Format(div,radio,label));

实测FF/IE浏览器效果相同

radio元素被隐藏,图中的按钮均为带css的label标签,当设置AutoPostBack=true时的回调也正常

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值