Any*_*are 6 javascript css asp.net ajax jquery
我在gridview中设置了一组文本框,我使用该Focus()方法在丢失到预期的文本框后恢复焦点.问题是 :
页面(可滚动),当我调用Focus方法时,在文本更改事件中,页面跳转到顶部.这是一个令人困惑的行为.
我的问题是:
有没有办法阻止该Focus()方法将页面跳到顶部?
我的代码:
protected void txt_evaluateWeights_TextChanged(object sender, EventArgs e)
{
calc();
int index = ((System.Web.UI.WebControls.GridViewRow)(((RadTextBox)sender).Parent.NamingContainer)).DataItemIndex;
((RadTextBox)gv_Evaluation.Rows[index + 1].Cells[3].FindControl("txt_evaluateWeights")).Focus();//Here is the problem.
}
Run Code Online (Sandbox Code Playgroud)
注意:
我使用了asp:TextBox,同样的问题.
我在更新面板中的网格视图
编辑:
Javascript解决方法:
var lastFocusedControlId = "";
function focusHandler(e) {
document.activeElement = e.originalTarget;
}
function appInit() {
if (typeof (window.addEventListener) !== "undefined") {
window.addEventListener("focus", focusHandler, true);
}
Sys.WebForms.PageRequestManager.getInstance().add_pageLoading(pageLoadingHandler);
Sys.WebForms.PageRequestManager.getInstance().add_pageLoaded(pageLoadedHandler);
}
function pageLoadingHandler(sender, args) {
lastFocusedControlId = typeof (document.activeElement) === "undefined"
? "" : document.activeElement.id;
}
function focusControl(targetControl) {
if (Sys.Browser.agent === Sys.Browser.InternetExplorer) {
var focusTarget = targetControl;
if (focusTarget && (typeof (focusTarget.contentEditable) !== "undefined")) {
oldContentEditableSetting = focusTarget.contentEditable;
focusTarget.contentEditable = false;
}
else {
focusTarget = null;
}
try {
targetControl.focus();
if (focusTarget) {
focusTarget.contentEditable = oldContentEditableSetting;
}
}
catch (err) { }
}
else {
targetControl.focus();
}
}
function pageLoadedHandler(sender, args) {
if (typeof (lastFocusedControlId) !== "undefined" && lastFocusedControlId != "") {
var newFocused = $get(lastFocusedControlId);
if (newFocused) {
focusControl(newFocused);
}
}
}
Sys.Application.add_init(appInit);
Run Code Online (Sandbox Code Playgroud)
除了尝试修复 Focus 方法的行为方式之外,还有另一种选择。我还没有尝试过,但是这个页面讨论了这个问题,还有一些客户端 JavaScript 来记住哪个控件拥有焦点,然后在 UpdatePanel 刷新后将焦点放回到该对象上。请务必阅读评论以了解脚本的一些更新。
如果您使用此方法,您将在代码隐藏中删除对 Focus on 的调用,并让此脚本在客户端上处理它。
| 归档时间: |
|
| 查看次数: |
6460 次 |
| 最近记录: |