ASP.NET页面中控制部分元素隐现的方法
ASP.Net控件模板中根据绑定对象的属性控制元素隐现技巧
在ASP.Net页面中,控制部分元素隐现通常采用这种方法:
<% if (this.显示编辑面板) { %>
……要显示的Html代码……
<% } %>
这种用法很方便,但是如果希望在服务器控件模板中使用它,以对绑定对象的某个属性进行判断时,这样写就会报错了:
<% if (Eval("默认照片") != null) { %>
……要显示的Html代码……
<% } %>
因为我们的代码写在了<% …… %>里,而如果要获取当前绑定对象的属性,需要将代码写入<%# …… %>,但是仅仅这样修改也是不对的:
<%# if (Eval("默认照片") != null) { %>
……要显示的Html代码……
<% } %>
那么正确的做法应该是怎样的呢?下面提供三种正确的做法:
直接在内嵌代码中判断和输出文本:
<%# (bool)Eval("是否用作默认照片")?"当前默认图像":string.Empty%>
此方法适合于仅输出文本的情况下。注:“是否用作默认照片”是当前绑定对象的一个bool类型属性
在服务器控件的Visible属性中嵌入代码进行判断:
<asp:Button ID="Button1" runat="server" Text="设为默认图像" CommandName="SetDefaultImage" Visible='<%# !(bool)Eval("是否用作默认照片") %>' />
此方法适合只需控制单一控件隐现的情况。注:“是否用作默认照片”是当前绑定对象的一个bool类型属性
使用PlaceHolder控件作为容器装载多个元素,在其Visible属性中内嵌代码控制内部多个元素的隐现:
<asp:PlaceHolder ID="PlaceHolder1" runat="server" Visible='<%#Eval("默认照片") != null %>'>默认照片: <a target='_blank' title='点击打开原始尺寸图像' href='<%# Eval("默认照片.全尺寸图文件路径") %>'>
<img alt='默认照片' src='<%# Eval("默认照片.页面缩略图文件路径") %>' />
<br /></asp:PlaceHolder>
此方法适合需同时控制多个元素隐现的情况。注:“默认照片”是当前绑定对象的一个自定义类型的属性