zoukankan      html  css  js  c++  java
  • HiddenField控件的使用

    ASP.NET2.0 HiddenField控件(1)2007-05-12 23:18HiddenField控件顾名思义就是隐藏输入框的服务器控件,它能让你保存那些不需要显示在页面上的且对安全性要求不高的数据。也许这个时候应该有这么一个疑问,为什么有了ViewState、Session和Cookie等状态保存机制,还需要用起HiddenField呢? 
       增加HiddenField,其实是为了让整个状态管理机制的应用程度更加全面。因为不管是ViewState、Cookie还是Session,都有其失效的时候,比如用户因某种需求要求设置ViewState为false,或者环境条件限制使用Cookie,或者用户长时间没有动作导致Session过期等等,那这个时候HiddenField无疑是最佳选择。 
       
        HiddenField控件的作用简单的说是用于存储需要在向服务器的发送间保持的值。它作为 <input type= "hidden"/> 元素呈现,并且通过添加runat=”server”就可以使它成为标准的HTML服务器控件。下面列出的是ASP.NET HiddenField Web服务器控件可以使用的属性和事件。 
      

     <asp:HiddenField 
        EnableTheming="True|False" 
        EnableViewState="True|False" 
        ID="string" 
        OnDataBinding="DataBinding event handler" 
        OnDisposed="Disposed event handler" 
        OnInit="Init event handler" 
        OnLoad="Load event handler" 
        OnPreRender="PreRender event handler" 
        OnUnload="Unload event handler" 
        OnValueChanged="ValueChanged event handler" 
        runat="server" 
        SkinID="string" 
        Value="string" 
        Visible="True|False" 
       />    

        因为 HiddenField 的值将呈现给客户端浏览器,所以它不适用于存储安全敏感的值。若要为 HiddenField 控件指定值,请使用 Value 属性,请注意是Value而不是Text。事实上HiddenField并没有Text属性,这和DropDownList、CheckBoxList等标准按钮的属性命名方式一致。在标准的属性命名方式中,Text的值是呈现给用户看到的,而Value的值则是通长是通过代码进行控制的。例如你可以让DropDownList的Text属性显示用户名而让它的Value存储用户的编号。 
        下面的代码显示的是改控件的基本使用。 
      

     <html> 
       <head> 
        <script language="C#" runat="server"> 
        void Button1_Click(object sender, EventArgs e) 
        { 
        if (HiddenField1.Value == String.Empty) 
        HiddenField1.Value = "0"; 
       
        HiddenField1.Value = (Convert.ToInt32(HiddenField1.Value)+1).ToString(); 
        Label1.Text = HiddenField1.Value; 
        } 
        </script> 
       </head> 
       <body> 
        <h3><font face="Verdana">HiddenField</font></h3> 
        <form runat=server> 
        <asp:HiddenField id=HiddenField1 runat=Server /> 
        <asp:Button id=Button1 Text="单击按钮" onclick="Button1_Click" runat="server" /> 
        单击 <asp:Label id=Label1 Text="0" runat=server /></form> 
        </body> 
       </html> 

       
        在上面代码中, <asp:HiddenField id=HiddenField1 runat=Server />就定义了一个隐藏控件在按钮的单击事件里计算用户单击的次数,并将改次数赋值给Label1。 
       
        你可以将上面代码中的 <asp:HiddenField id=HiddenField1 runat=Server />改为<input type=hidden id=HiddenField1 runat=Server >也是可以的 
       
       在使用上面代码里,如果你从浏览器里查看源代码会得到如下的信息: 
       <form name="Form1" method="post" action="Default.aspx" id="Form1"> 
        这是因为HiddenField是通过HTTP协议进行传递数据的,所以如果你通过" method="get"或者链接打开新的窗体页,那么HiddenField并不可用。 
        另外,HiddenField并不是取代Session来维护状态的,在上面例子里,虽然你点击一次按钮可以显示你点击的次数但是并不是说它可以记录你的状态信息。如果你重新打开浏览器那么你看到的此处仍然是0而不是3。 
       
       HiddenField事件 
        HiddenField较为常用的是ValueChanged事件,该事件在Value值发生改变时触发该事件。然而在实际使用时,要知道页面记载顺序。在页面回传过程中,具体的页面周期你可以到如下网站查看 
       http://msdn2.microsoft.com/zh-cn/library/ms178472.aspx 
        下面的例子说明了这个问题 
       
     

      <head> 
       <script runat="server" language="c#"> 
        protected void Page_Load(object sender, EventArgs e) 
        { 
         Response.Write(
    "<p>页面的Page_Load事件触发,触发时间是:" + DateTime.Now.ToString());   if (HiddenField1.Value == String.Empty)   HiddenField1.Value = "0";
      } protected
    void Button1_Click(object sender, EventArgs e) {
         Response.Write(
    "<p>Button1_Click为改变Hidden的值前事件触发,触发时间是:" + DateTime.Now.ToString());   HiddenField1.Value = (Convert.ToInt32(HiddenField1.Value) + 1).ToString();   Label1.Text = HiddenField1.Value; } protected void HiddenField1_ValueChanged(object sender, EventArgs e) {
        Response.Write(
    "<p>HiddenField的 ValueChanged事件触发,触发时间是:" + DateTime.Now.ToString());
       }
    </script> </head> <body> <form id="form1" runat="server"> <div> <asp:HiddenField ID="HiddenField1" runat="server" OnValueChanged="HiddenField1_ValueChanged" /> </div> <asp:Label ID="Label1" runat="server" Text="Label"></asp:Label> <br /> <asp:Button ID="Button1" runat="server" OnClick="Button1_Click" Text="Button" /> </form></body> </html>
  • 相关阅读:
    javascript 字符串与正则
    微信小程序 实现三级联动-省市区
    VUE图片懒加载-vue lazyload插件的简单使用
    移动端使用mint-ui loadmore实现下拉刷新上拉显示更多
    vue-cli创建的项目中引入第三方库报错 'caller', 'calle', and 'arguments' properties .....报错问题
    js判断两个数组是否相等
    234回文链表
    剑指 Offer 22. 链表中倒数第k个节点
    返回倒数第 k 个节点
    leetcode 179.最大数
  • 原文地址:https://www.cnblogs.com/weicleer/p/2788722.html
Copyright © 2011-2022 走看看