更新表单后,继续关注ajax更新面板

时间:2009-05-12 15:32:58

标签: asp.net javascript updatepanel tabbing

我有一个formview,旨在每次更改text_changed事件或下拉列表时更新它的数据源。在每个text_changed事件和其他控件的等效事件上,我调用formView.UpdateItem方法,这会导致表单从我已选中的控件中失去焦点。

我尝试实现this method,但在尝试第二次选择控件后,我得到了未知的运行时错误。

我不禁想到还有另一种方法可以解决这个问题。

你将如何解决这个问题?

2 个答案:

答案 0 :(得分:1)

对于这样的事情,我经常使用javascript将值隐藏在asp:隐藏控件(输入类型=“隐藏”)中,然后添加一个pageLoad函数(在javascript中)来解析该字段然后设置焦点。这样,聚焦控件的id就会通过回发保持不变。

像这样(伪代码):

<input type="hidden" id="focusHolder" />

function onSubmit (registered via ClientScript.RegisterOnSubmitStatemnet) {
grab the target and stash id in #focusHolder
}

function pageLoad() {
$get($get('focusHolder').value).focus();
}

答案 1 :(得分:0)

您也可以在服务器端执行此操作。下面是一个如何将焦点放在导致异步回发的控件上的示例:

    protected void Page_Load(object sender, EventArgs e)
    {
        if (IsPostBack)
        {
            if (ScriptManager.GetCurrent(Page).IsInAsyncPostBack)
            {
                string IDPostbackCtrl = GetAsyncPostBackControlID(Page, Page.Request);
                ScriptManager.GetCurrent(Page).SetFocus(IDPostbackCtrl);
            }
        }
    }

    public string GetAsyncPostBackControlID(Page page, HttpRequest request)
    {
        string smUniqueId = ScriptManager.GetCurrent(page).UniqueID;
        string smFieldValue = request.Form[smUniqueId];

        if (!String.IsNullOrEmpty(smFieldValue) && smFieldValue.Contains('|'))
            return smFieldValue.Split('|')[1];

        return String.Empty;
    }