UIWebView 抛出 NSUnknownKeyException iPad

发布于 2024-10-14 19:10:26 字数 5289 浏览 9 评论 0原文

我有一个标签栏应用程序。一切正常,我可以在选项卡之间正常切换,但当我切换到第二个选项卡 ProductViewClass 时,视图不会更新,并且会输出下面的控制台输出。除了 UIWebView 和 UILabel 之外,我在这个视图中没有任何东西。当我删除 UIWebView 时,它会成功运行,当我添加另一个 UIWebView 时,它仍然可以工作。仅当我将文件所有者的 IBOutlet 连接到 UIWebView 时,它才会停止工作。除了合成和发布 productWebView 之外,ProductWebView.m 中唯一的非模板代码是这样的:

    NSString *urlString = @"http://www.google.com/";
    NSURL *theURL = [NSURL URLWithString:urlString];
    NSURLRequest *urlRequest = [NSURLRequest requestWithURL:theURL];
    [productWebView loadRequest:urlRequest];
    NSLog(@"Google loaded");

ProductWebView.h 的全部内容如下:

#import <UIKit/UIKit.h>
@interface ProductViewClass : UIViewController {

    IBOutlet UIWebView *productWebView;
}

@property(nonatomic, retain) UIWebView *productWebView;
@end

这是控制台输出:

This GDB was configured as "x86_64-apple-darwin".Attaching to process 52523.
2011-01-30 19:18:28.907 FairCom[52523:40b] *** Terminating app due to uncaught exception 'NSUnknownKeyException', reason: '[<UIViewController 0x4d06eb0> setValue:forUndefinedKey:]: this class is not key value coding-compliant for the key productWebView.'
*** Call stack at first throw:
(
    0   CoreFoundation                      0x00da8be9 __exceptionPreprocess + 185
    1   libobjc.A.dylib                     0x00efd5c2 objc_exception_throw + 47
    2   CoreFoundation                      0x00da8b21 -[NSException raise] + 17
    3   Foundation                          0x000296cf _NSSetUsingKeyValueSetter + 135
    4   Foundation                          0x0002963d -[NSObject(NSKeyValueCoding) setValue:forKey:] + 285
    5   UIKit                               0x004a88d6 -[UIRuntimeOutletConnection connect] + 112
    6   CoreFoundation                      0x00d1f2cf -[NSArray makeObjectsPerformSelector:] + 239
    7   UIKit                               0x004a72ed -[UINib instantiateWithOwner:options:] + 1041
    8   UIKit                               0x004a9081 -[NSBundle(UINSBundleAdditions) loadNibNamed:owner:options:] + 168
    9   UIKit                               0x00361a94 -[UIViewController _loadViewFromNibNamed:bundle:] + 70
    10  UIKit                               0x0035f709 -[UIViewController loadView] + 120
    11  UIKit                               0x0035f5e3 -[UIViewController view] + 56
    12  UIKit                               0x00372230 -[UITabBarController transitionFromViewController:toViewController:transition:shouldSetSelected:] + 120
    13  UIKit                               0x00370d86 -[UITabBarController transitionFromViewController:toViewController:] + 64
    14  UIKit                               0x00372b7e -[UITabBarController _setSelectedViewController:] + 263
    15  UIKit                               0x003729ed -[UITabBarController _tabBarItemClicked:] + 352
    16  UIKit                               0x002b1a6e -[UIApplication sendAction:to:from:forEvent:] + 119
    17  UIKit                               0x004af1f2 -[UITabBar _sendAction:withEvent:] + 422
    18  UIKit                               0x002b1a6e -[UIApplication sendAction:to:from:forEvent:] + 119
    19  UIKit                               0x003401b5 -[UIControl sendAction:to:forEvent:] + 67
    20  UIKit                               0x00342647 -[UIControl(Internal) _sendActionsForEvents:withEvent:] + 527
    21  UIKit                               0x0034016c -[UIControl sendActionsForControlEvents:] + 49
    22  UIKit                               0x002b1a6e -[UIApplication sendAction:to:from:forEvent:] + 119
    23  UIKit                               0x003401b5 -[UIControl sendAction:to:forEvent:] + 67
    24  UIKit                               0x00342647 -[UIControl(Internal) _sendActionsForEvents:withEvent:] + 527
    25  UIKit                               0x003411f4 -[UIControl touchesEnded:withEvent:] + 458
    26  UIKit                               0x002d60d1 -[UIWindow _sendTouchesForEvent:] + 567
    27  UIKit                               0x002b737a -[UIApplication sendEvent:] + 447
    28  UIKit                               0x002bc732 _UIApplicationHandleEvent + 7576
    29  GraphicsServices                    0x016dea36 PurpleEventCallback + 1550
    30  CoreFoundation                      0x00d8a064 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE1_PERFORM_FUNCTION__ + 52
    31  CoreFoundation                      0x00cea6f7 __CFRunLoopDoSource1 + 215
    32  CoreFoundation                      0x00ce7983 __CFRunLoopRun + 979
    33  CoreFoundation                      0x00ce7240 CFRunLoopRunSpecific + 208
    34  CoreFoundation                      0x00ce7161 CFRunLoopRunInMode + 97
    35  GraphicsServices                    0x016dd268 GSEventRunModal + 217
    36  GraphicsServices                    0x016dd32d GSEventRun + 115
    37  UIKit                               0x002c042e UIApplicationMain + 1160
    38  FairCom                             0x00001be0 main + 102
    39  FairCom                             0x00001b71 start + 53
    40  ???                                 0x00000001 0x0 + 1
)
terminate called after throwing an instance of 'NSException'
sharedlibrary apply-load-rules all
(gdb) 

感谢您的帮助帮助!

I have a tab bar application. Everything works normally, and I can switch between tabs fine and everything, except when I switch to my second tab ProductViewClass the view doesn't update and it spits out the console output below. I have nothing in this view except for a UIWebView and a UILabel. When I delete the UIWebView it runs successfully, and when I add another it still works. It only stops working when I connect the IBOutlet from my File's Owner to the UIWebView. Besides synthesizing and releasing productWebView the only non-template code in ProductWebView.m is this:

    NSString *urlString = @"http://www.google.com/";
    NSURL *theURL = [NSURL URLWithString:urlString];
    NSURLRequest *urlRequest = [NSURLRequest requestWithURL:theURL];
    [productWebView loadRequest:urlRequest];
    NSLog(@"Google loaded");

The entirety of ProductWebView.h is as follows:

#import <UIKit/UIKit.h>
@interface ProductViewClass : UIViewController {

    IBOutlet UIWebView *productWebView;
}

@property(nonatomic, retain) UIWebView *productWebView;
@end

Here's the console output:

This GDB was configured as "x86_64-apple-darwin".Attaching to process 52523.
2011-01-30 19:18:28.907 FairCom[52523:40b] *** Terminating app due to uncaught exception 'NSUnknownKeyException', reason: '[<UIViewController 0x4d06eb0> setValue:forUndefinedKey:]: this class is not key value coding-compliant for the key productWebView.'
*** Call stack at first throw:
(
    0   CoreFoundation                      0x00da8be9 __exceptionPreprocess + 185
    1   libobjc.A.dylib                     0x00efd5c2 objc_exception_throw + 47
    2   CoreFoundation                      0x00da8b21 -[NSException raise] + 17
    3   Foundation                          0x000296cf _NSSetUsingKeyValueSetter + 135
    4   Foundation                          0x0002963d -[NSObject(NSKeyValueCoding) setValue:forKey:] + 285
    5   UIKit                               0x004a88d6 -[UIRuntimeOutletConnection connect] + 112
    6   CoreFoundation                      0x00d1f2cf -[NSArray makeObjectsPerformSelector:] + 239
    7   UIKit                               0x004a72ed -[UINib instantiateWithOwner:options:] + 1041
    8   UIKit                               0x004a9081 -[NSBundle(UINSBundleAdditions) loadNibNamed:owner:options:] + 168
    9   UIKit                               0x00361a94 -[UIViewController _loadViewFromNibNamed:bundle:] + 70
    10  UIKit                               0x0035f709 -[UIViewController loadView] + 120
    11  UIKit                               0x0035f5e3 -[UIViewController view] + 56
    12  UIKit                               0x00372230 -[UITabBarController transitionFromViewController:toViewController:transition:shouldSetSelected:] + 120
    13  UIKit                               0x00370d86 -[UITabBarController transitionFromViewController:toViewController:] + 64
    14  UIKit                               0x00372b7e -[UITabBarController _setSelectedViewController:] + 263
    15  UIKit                               0x003729ed -[UITabBarController _tabBarItemClicked:] + 352
    16  UIKit                               0x002b1a6e -[UIApplication sendAction:to:from:forEvent:] + 119
    17  UIKit                               0x004af1f2 -[UITabBar _sendAction:withEvent:] + 422
    18  UIKit                               0x002b1a6e -[UIApplication sendAction:to:from:forEvent:] + 119
    19  UIKit                               0x003401b5 -[UIControl sendAction:to:forEvent:] + 67
    20  UIKit                               0x00342647 -[UIControl(Internal) _sendActionsForEvents:withEvent:] + 527
    21  UIKit                               0x0034016c -[UIControl sendActionsForControlEvents:] + 49
    22  UIKit                               0x002b1a6e -[UIApplication sendAction:to:from:forEvent:] + 119
    23  UIKit                               0x003401b5 -[UIControl sendAction:to:forEvent:] + 67
    24  UIKit                               0x00342647 -[UIControl(Internal) _sendActionsForEvents:withEvent:] + 527
    25  UIKit                               0x003411f4 -[UIControl touchesEnded:withEvent:] + 458
    26  UIKit                               0x002d60d1 -[UIWindow _sendTouchesForEvent:] + 567
    27  UIKit                               0x002b737a -[UIApplication sendEvent:] + 447
    28  UIKit                               0x002bc732 _UIApplicationHandleEvent + 7576
    29  GraphicsServices                    0x016dea36 PurpleEventCallback + 1550
    30  CoreFoundation                      0x00d8a064 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE1_PERFORM_FUNCTION__ + 52
    31  CoreFoundation                      0x00cea6f7 __CFRunLoopDoSource1 + 215
    32  CoreFoundation                      0x00ce7983 __CFRunLoopRun + 979
    33  CoreFoundation                      0x00ce7240 CFRunLoopRunSpecific + 208
    34  CoreFoundation                      0x00ce7161 CFRunLoopRunInMode + 97
    35  GraphicsServices                    0x016dd268 GSEventRunModal + 217
    36  GraphicsServices                    0x016dd32d GSEventRun + 115
    37  UIKit                               0x002c042e UIApplicationMain + 1160
    38  FairCom                             0x00001be0 main + 102
    39  FairCom                             0x00001b71 start + 53
    40  ???                                 0x00000001 0x0 + 1
)
terminate called after throwing an instance of 'NSException'
sharedlibrary apply-load-rules all
(gdb) 

Thanks for your help!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

撩发小公举 2024-10-21 19:10:26

您正在加载笔尖。在该笔尖中,您有一个名为 productWebView 的插座,它可能连接到 Web 视图。您看到的异常是告诉您出口 productWebView 实际上并不存在。这就是奇怪的地方。该错误表明对象 是缺少此插座的对象。奇怪的是它显示的是 UIViewController 而不是实际视图控制器子类的名称。听起来您有一个笔尖,其中文件的所有者被设置为视图控制器子类之一,但在运行时您实际上只是直接使用 UIViewController 的实例。您应该验证选项卡栏控制器中代表选项卡的所有视图控制器是否都是 UIViewController 的实际正确子类,而不仅仅是 UIViewController 本身的实例。

You're loading a nib. In that nib, you have an outlet named productWebView that's hooked up, presumably to a web view. The exception you're seeing is telling you that the outlet productWebView doesn't actually exist. Here's where it gets weird. The error says the object <UIViewController 0x4d06eb0> is the one that has this missing outlet. The weird bit is where it says UIViewController instead of the name of an actual view controller subclass. It sounds like you have a nib where the File's Owner is set up as one of your view controller subclasses, but at runtime you're actually just using an instance of UIViewController directly. You should verify that all the view controllers representing tabs in your tab bar controller are actual correct subclasses of UIViewController instead of just an instance of UIViewController itself.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文