macOS WKwebview的简单实现

1.最简单的,只显示内容没有交互。

 

 复制代码即可运行,可拖拽窗口。

#import "ViewController.h"
#import <WebKit/WebKit.h>
@interface ViewController ()
@property (nonatomic,strong)WKWebView * webView;
@end

@implementation ViewController

-(void)viewDidLoad {
    [super viewDidLoad];
    //观察窗口拉伸
    [[NSNotificationCenter defaultCenter]addObserver:self selector:@selector(screenResize)
                                                name:NSWindowDidResizeNotification
                                              object:nil];

    //初始化
    _webView = [[WKWebView alloc] initWithFrame:CGRectMake(0, 0, self.view.bounds.size.width, self.view.bounds.size.height)];
    //加载出来
    [self.view addSubview:_webView];

    //1.网络
    _webView.allowsBackForwardNavigationGestures = YES;
    NSMutableURLRequest * request = [NSMutableURLRequest requestWithURL:[NSURL URLWithString:@"https://www.hao123.com/"]];

    [_webView loadRequest:request];
}

-(void)screenResize{
    
    NSLog(@"观察窗口拉伸");
    NSLog(@"%.2f===%.2f",self.view.bounds.size.width,self.view.bounds.size.height);

    _webView.frame = CGRectMake(0, 0, self.view.bounds.size.width, self.view.bounds.size.height);
    
}

- (void)setRepresentedObject:(id)representedObject {
    [super setRepresentedObject:representedObject];

    // Update the view, if already loaded.
}


@end

注意⚠️如果发现界面是黑屏或者是白屏那就是有两处地方你还没有做配置

此处也可以参考:https://www.jianshu.com/p/d7e96597bd1f

1.是网络权限的配置

参考我的上一篇:https://www.cnblogs.com/gaozhang12345/p/15979220.html

2.是沙盒模式下的网络权限配置

参考这张截图:

 

最近在做项目的时候遇到一个奇怪的问题,WKWebView加载一些页面的时候会出现页面内无法跳转链接,但是有些网页是可以的,最后查阅了很多资料才找到最终解决办法。

此处感谢 

2.可进行简单的交互增加代码如下

(1)引进代理

@interface ViewController ()<WKNavigationDelegate>

(2)增加代理引用的地方

//1.网络
    self.webView.navigationDelegate = self;

(3)实现下面的代理方法

- (void)webView:(WKWebView *)webView decidePolicyForNavigationAction:(WKNavigationAction *)navigationAction decisionHandler:(void (^)(WKNavigationActionPolicy))decisionHandler {

    if (navigationAction.targetFrame == nil) {

        [webView loadRequest:navigationAction.request];

    }

    decisionHandler(WKNavigationActionPolicyAllow);

}

运行之后,代码就可以实现简单的交互了。

3.增加前进后退页面

待续

4.遇到需要上传图片的网页,比如说

https://www.gaitubao.com/tupian-wenzi

那么我们就要调用MAC的文件选择管理器的代理了
在WKWebView的UIDelegate事件中,调起文件选择对话框,并将选取的文件回调回去。

self.webView.UIDelegate = self;
- (void)webView:(WKWebView*)webView runOpenPanelWithParameters:(WKOpenPanelParameters*)parameters initiatedByFrame:(WKFrameInfo*)frame completionHandler:(nonnull void (^)(NSArray<NSURL *> * _Nullable))completionHandler {
    NSOpenPanel* panel = [NSOpenPanel openPanel];
    panel.allowsMultipleSelection = parameters.allowsMultipleSelection;
    panel.canChooseDirectories = parameters.allowsDirectories;
    panel.allowedFileTypes = @[@"png", @"jpg", @"BMP", @"TIFF"];//图片类型
    NSModalResponse result = [panel runModal];
    if (result == NSModalResponseOK) {
        completionHandler([panel URLs]);
    }
    else {
        completionHandler(nil);
    }
}

鸣谢:

就可以拉起文件或者图片选择弹框了

 

posted on 2022-03-09 10:43  高彰  阅读(1036)  评论(0编辑  收藏  举报

导航