这节我们学习三个控件,他们分别是:HiddenField,Literal,LinkButton
我们这里的演示用LinkButton ,因为这个控件在用法上和BUTTON 差不多,就长相有点希奇,也许是控件们性开放,HyperLink和Button瞎整,结果就有了LinkButton ,可你别说,他虽然这样名不正言不顺的出来了,可他的贡献是很不错的,所以,得表扬!
我们是首先学习 HiddenField ,他提供了一种方式实现在页面存储信息,并且与其他的控件信息用法差不多,但是他不显示出来,说到这,顺便说下,不要以为他不显示就怎么样了,你仍然不要往里面存放类似密码等敏感信息,因为在页面HTML源中是可以看见的.
LinkButton
接下来我们说Literal: 这个控件我们用得不多,甚至是很少,但是既然微软作出来了,我们就有义务说说.免得被人说我不厚道.何况这也是2.0才出来的一个新玩意,哈哈!!!
我懒得打字了,复制MSDN 上的东西了
Literal 控件表示用于向页面添加内容的几个选项之一。对于静态内容,无需使用容器,可以将标记作为 HTML 直接添加到页面中。但是,如果要动态添加内容,则必须将内容添加到容器中。典型的容器有 Label控件、Literal 控件、Panel控件和 Placeholder 控件。
Literal 控件与 Label 控件的区别在于 Literal 控件不向文本中添加任何 HTML 元素。(Label 控件呈现一个 span 元素。)因此,Literal 控件不支持包括位置属性在内的任何样式属性。但是,Literal 控件允许指定是否对内容编码。
Panel 和 Placeholder 控件呈现为 div 元素,这将在页面中创建离散块,与 Label 和 Literal 控件进行内嵌呈现的方式不同。
通常情况下,当希望文本和控件直接呈现在页面中而不使用任何附加标记时,可使用 Literal 控件。
Literal 控件支持 Mode 属性,该属性用于指定控件对您所添加的标记的处理方式。可以将 Mode 属性设置为以下值:
Transform 。添加到控件中的任何标记都将进行转换,以适应请求浏览器的协议。如果向使用 HTML 外的其他协议的移动设备呈现内容,此设置非常有用。
PassThrough 。添加到控件中的任何标记都将按原样呈现在浏览器中。
Encode 。添加到控件中的任何标记都将使用 HtmlEncode 方法进行编码,该方法将把 HTML 编码转换为其文本表示形式。例如,<b> 标记将呈现为 <b>。当希望浏览器显示而不解释标记时,编码将很有用。编码对于安全也很有用,有助于防止在浏览器中执行恶意标记,显示来自不受信任的源的字符串时推荐使用此设置。
使用了Transform模式
--------------------------------------------------------------------------------
[fdsf](desf);"hahah"
使用了PassThrough 模式
--------------------------------------------------------------------------------
[fdsf](desf);"hahah"
使用了Encode 模式
<hr><i>[fdsf](desf);"hahah"<br><p></i>
这是正常模式的 Label
--------------------------------------------------------------------------------
[fdsf](desf);"hahah"
这是使用了Server.HtmlEncode方法解码的方式
<hr><i>[fdsf](desf);"hahah"<br><p></i>