Javascript UIWebView在键盘出现时滚动。导致抽头偏移错误?

Javascript UIWebView在键盘出现时滚动。导致抽头偏移错误?,javascript,ios,iphone,uiwebview,Javascript,Ios,Iphone,Uiwebview,我有一个带有登录字段的UIWebView,需要用户输入iPad应用程序。视图以模式显示,当显示键盘时,会导致UIWebView向上滚动。 这就是bug发生的地方,UIWebView包含一个点击延迟,我还没有找到可靠的解决方案。(我使用的是OAuth,因此任何Javascript注入都无法可靠地工作)。键盘是显示的,所以当我点击输入字段时,点击会在视图自动滚动后注册,并且不在正确的位置 基本上,这使得我点击顶部的输入字段,点击比它应该的低约20px,因为视图被键盘移动 我曾尝试阻止UIWebVie

我有一个带有登录字段的
UIWebView
,需要用户输入iPad应用程序。视图以模式显示,当显示键盘时,会导致
UIWebView
向上滚动。

这就是bug发生的地方,
UIWebView
包含一个点击延迟,我还没有找到可靠的解决方案。(我使用的是
OAuth
,因此任何
Javascript
注入都无法可靠地工作)。键盘是显示的,所以当我点击输入字段时,点击会在视图自动滚动后注册,并且不在正确的位置

基本上,这使得我点击顶部的输入字段,点击比它应该的低约20px,因为视图被键盘移动

我曾尝试阻止
UIWebView
滚动,但不管发生什么情况,键盘总是会使其移动。 我尝试注入
Javascript
来消除点击延迟,但也没有成功


感谢您的帮助

我也在努力解决这个问题。我还没有解决抽头偏移问题,但只要关闭抽头延迟,您可以使用:

[[self.webView scrollView] setDelaysContentTouches:NO];
不确定是否已找到此页面,但您可以添加键盘通知的侦听器,并自行操作滚动。以下是苹果的文档链接:

以下是链接中有关操作视图的代码:

// Call this method somewhere in your view controller setup code.
- (void)registerForKeyboardNotifications
{
[[NSNotificationCenter defaultCenter] addObserver:self
        selector:@selector(keyboardWasShown:)
        name:UIKeyboardDidShowNotification object:nil];

[[NSNotificationCenter defaultCenter] addObserver:self
         selector:@selector(keyboardWillBeHidden:)
         name:UIKeyboardWillHideNotification object:nil];

}


// Called when the UIKeyboardDidShowNotification is sent.
- (void)keyboardWasShown:(NSNotification*)aNotification
{
NSDictionary* info = [aNotification userInfo];
CGSize kbSize = [[info objectForKey:UIKeyboardFrameBeginUserInfoKey] CGRectValue].size;

UIEdgeInsets contentInsets = UIEdgeInsetsMake(0.0, 0.0, kbSize.height, 0.0);
scrollView.contentInset = contentInsets;
scrollView.scrollIndicatorInsets = contentInsets;

// If active text field is hidden by keyboard, scroll it so it's visible
// Your app might not need or want this behavior.
CGRect aRect = self.view.frame;
aRect.size.height -= kbSize.height;
if (!CGRectContainsPoint(aRect, activeField.frame.origin) ) {
    [self.scrollView scrollRectToVisible:activeField.frame animated:YES];
}
}

// Called when the UIKeyboardWillHideNotification is sent
- (void)keyboardWillBeHidden:(NSNotification*)aNotification
{
UIEdgeInsets contentInsets = UIEdgeInsetsZero;
scrollView.contentInset = contentInsets;
scrollView.scrollIndicatorInsets = contentInsets;
}
uiwebview中的一些热门领域似乎并不总是随着键盘的移动而向上移动。解决这个问题的一个肮脏的方法是在按钮/etc上放置一个不可见的文本div,并使用一些空格,让它调用一个javascript函数,尝试完成任何触摸事件都没有注册。像这样:

<div id="someBtn" onclick="tryAction();">&nbsp;&nbsp;&nbsp;&nbsp;</div>


我希望这对您有所帮助,或者至少为您指明了一个有用的方向。

您从哪里获得变量activeField?