简单方法使页面回发后保持焦点

本文将使用一个简单的方法使页面回发后还在同一个控件上保持焦点。
 
一般来说,当页面回发后,原来的焦点控件将失去焦点。有很多文章讨论过这个话题,但是一般都是使用JQuery来解决的。我来教大家一个简单的方法:使用Session。
 
首先在页面上放三个文本框 ,并且都生成 Ontextchanged事件。
 
  < asp:TextBox ID =" TextBox1" runat =" server" AutoPostBack =" True" ontextchanged =" TextBox1_TextChanged" TabIndex =" 1" > < / asp:TextBox >
< asp:TextBox ID =" TextBox2" runat =" server" AutoPostBack =" True" ontextchanged =" TextBox2_TextChanged" TabIndex =" 2" > < / asp:TextBox >
< asp:TextBox ID =" TextBox3" runat =" server" AutoPostBack =" True" ontextchanged =" TextBox3_TextChanged" TabIndex =" 3" > < / asp:TextBox >
然后,在事件中,将焦点存入Session:
 
protected void TextBox1_TextChanged(object sender, EventArgs e)
        {
            Session["event_controle"] = ((TextBox)sender);
        }
 
        protected void TextBox2_TextChanged(object sender, EventArgs e)
        {
            Session["event_controle"] = ((TextBox)sender);
        }
 
        protected void TextBox3_TextChanged(object sender, EventArgs e)
        {
            Session["event_controle"] = ((TextBox)sender);
        } 


最后,在页面生成时,载入焦点:
protected void Page_PreRender(object sender, EventArgs e)
        {
            try
            {
                if (Session["event_controle"] != null)
                { 
                    TextBox controle =(TextBox) Session["event_controle"];
 
                    controle.Focus(); 
                }
            }
            catch (InvalidCastException inEx)
            {
            }        
        } 
 
 
本文译自codeproject.com 

 

转载于:https://www.cnblogs.com/ranzige/p/FocusControl.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值