如何迁移到WKWebView?

Dan*_*son 58 uiwebview ios8 wkwebview

我试图了解如何在iOS8中使用新的WKWebView,找不到太多信息.我读了:

http://developer.telerik.com/featured/why-ios-8s-wkwebview-is-a-big-deal-for-hybrid-development/ http://nshipster.com/wkwebkit/

但这对现有应用程序有何影响?普通的UiWebView会从nitro java脚本引擎获得加速,还是需要进行更改?我们如何处理向后兼容性?

我能找到的所有代码和示例都使用swift,这是强制性的吗?

感谢您对此事的任何帮助!

kri*_*rak 59

UIWebView仍将继续使用现有的应用程序.WKWebView可用iOS8,只有WKWebView一个Nitro JavaScript引擎.

要在旧版应用程序中利用这个更快的JavaScript引擎,您必须更改代码以WKWebView代替使用UIWebView.对于iOS7旧版本,您必须继续使用UIWebView,因此您可能必须检查iOS8然后应用WKWebView方法/委托方法并回退到更旧的UIWebView方法iOS7.WKWebView(还)没有Interface Builder组件,因此您必须以编程方式实现WKWebView.

你可以WKWebView在Objective-C中实现,这里有一个简单的例子来启动WKWebView:

WKWebViewConfiguration *theConfiguration = [[WKWebViewConfiguration alloc] init];
WKWebView *webView = [[WKWebView alloc] initWithFrame:self.view.frame configuration:theConfiguration];
webView.navigationDelegate = self;
NSURL *nsurl=[NSURL URLWithString:@"http://www.apple.com"];
NSURLRequest *nsrequest=[NSURLRequest requestWithURL:nsurl];
[webView loadRequest:nsrequest];
[self.view addSubview:webView];
Run Code Online (Sandbox Code Playgroud)

WKWebView渲染性能在WebGL游戏中是显而易见的,并且运行复杂的JavaScript算法,如果您使用webview加载简单的html或网站,则可以继续使用UIWebView.

下面是测试的应用程序,可以用来使用既可以打开任何网站UIWebViewWKWebView你可以比较的表现,然后决定将应用升级为使用WKWebView: https://itunes.apple.com/app/id928647773?mt=8&at=10ltWQ

在此输入图像描述

  • 现在无法使用 UIWebView,您无法在使用它的商店中推送应用程序 (2认同)

小智 36

以下是我从UIWebView转换到WKWebView的方法.

注意:没有像UIWebView这样的属性可以拖到你的故事板上,你必须以编程方式进行.

确保将WebKit/WebKit.h导入头文件.

这是我的头文件:

#import <WebKit/WebKit.h>

@interface ViewController : UIViewController

@property(strong,nonatomic) WKWebView *webView;
@property (strong, nonatomic) NSString *productURL;

@end
Run Code Online (Sandbox Code Playgroud)

这是我的实现文件:

#import "ViewController.h"

@interface ViewController ()

@end


@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    self.productURL = @"http://www.URL YOU WANT TO VIEW GOES HERE";

    NSURL *url = [NSURL URLWithString:self.productURL];
    NSURLRequest *request = [NSURLRequest requestWithURL:url];

    _webView = [[WKWebView alloc] initWithFrame:self.view.frame];  
    [_webView loadRequest:request];
    _webView.frame = CGRectMake(self.view.frame.origin.x,self.view.frame.origin.y, self.view.frame.size.width, self.view.frame.size.height);
    [self.view addSubview:_webView];
}

- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}

@end
Run Code Online (Sandbox Code Playgroud)

  • 如何加载本地文件?我试过了,但页面上没有出现任何内容。还有什么是像 UIWebview 这样的委托方法。例如:didloadRequest (2认同)

Kir*_*odi 17

第1步:导入webkitViewController.swift

import WebKit
Run Code Online (Sandbox Code Playgroud)

步骤:2声明webView的变量.

var webView : WKWebView!
Run Code Online (Sandbox Code Playgroud)

步骤:3添加代表WKNavigationDelegate

class ViewController: UIViewController , WKNavigationDelegate{
Run Code Online (Sandbox Code Playgroud)

步骤:4添加代码ViewDidLoad.

let myBlog = "https://iosdevcenters.blogspot.com/"
let url = NSURL(string: myBlog)
let request = NSURLRequest(URL: url!)

// init and load request in webview.
webView = WKWebView(frame: self.view.frame)
webView.navigationDelegate = self
webView.loadRequest(request)
self.view.addSubview(webView)
self.view.sendSubviewToBack(webView)
Run Code Online (Sandbox Code Playgroud)

步骤:5编辑info.plist添加

<dict>
<key>NSAllowsArbitraryLoads</key>
<true/>
<key>NSExceptionDomains</key>
<dict>
<key>google.com</key>
<dict>
    <key>NSExceptionAllowsInsecureHTTPLoads</key>
    <true/>
    <key>NSIncludesSubdomains</key>
    <true/>
</dict>
</dict>
Run Code Online (Sandbox Code Playgroud)


wei*_*yin 10

Swift不是必需的,一切都适用于Objective-C.UIWebView将继续受到支持,因此如果您想花时间,不要急于迁移.但是,它不会获得WKWebView的javascript和滚动性能增强功能.

为了向后兼容,我的视图控制器有两个属性:UIWebView和WKWebView.只有在类存在时才使用WKWebview:

if ([WKWebView class]) {
    // do new webview stuff
} else {
    // do old webview stuff
}
Run Code Online (Sandbox Code Playgroud)

虽然我曾经有一个UIWebViewDelegate,但我也把它变成了WKNavigationDelegate并创建了必要的方法.


小智 7

根据Apple文档, WkWebView比UIWebview更快更可靠.在这里,我发布了我的WkWebViewController.

import UIKit
import WebKit

class WebPageViewController: UIViewController,UINavigationControllerDelegate,UINavigationBarDelegate,WKNavigationDelegate{

    var webView: WKWebView?
    var webUrl="http://www.nike.com"

    override func viewWillAppear(animated: Bool){
        super.viewWillAppear(true)
        navigationController!.navigationBar.hidden = false

    }
    override func viewDidLoad()
    {
        /* Create our preferences on how the web page should be loaded */
        let preferences = WKPreferences()
        preferences.javaScriptEnabled = false

        /* Create a configuration for our preferences */
        let configuration = WKWebViewConfiguration()
        configuration.preferences = preferences

        /* Now instantiate the web view */
        webView = WKWebView(frame: view.bounds, configuration: configuration)

        if let theWebView = webView{
            /* Load a web page into our web view */
            let url = NSURL(string: self.webUrl)
            let urlRequest = NSURLRequest(URL: url!)
            theWebView.loadRequest(urlRequest)
            theWebView.navigationDelegate = self
            view.addSubview(theWebView)

        }


    }
    /* Start the network activity indicator when the web view is loading */
    func webView(webView: WKWebView,didStartProvisionalNavigation navigation: WKNavigation){
            UIApplication.sharedApplication().networkActivityIndicatorVisible = true
    }

    /* Stop the network activity indicator when the loading finishes */
    func webView(webView: WKWebView,didFinishNavigation navigation: WKNavigation){
            UIApplication.sharedApplication().networkActivityIndicatorVisible = false
    }

    func webView(webView: WKWebView,
        decidePolicyForNavigationResponse navigationResponse: WKNavigationResponse,decisionHandler: ((WKNavigationResponsePolicy) -> Void)){
            //print(navigationResponse.response.MIMEType)
            decisionHandler(.Allow)

    }
    override func didReceiveMemoryWarning(){
        super.didReceiveMemoryWarning()
    }

}
Run Code Online (Sandbox Code Playgroud)


Pra*_*abu 5

在iOS 8中使用Swift的WKWebView ..

整个ViewController.swift文件现在看起来像这样:

import UIKit
import WebKit

class ViewController: UIViewController {

    @IBOutlet var containerView : UIView! = nil
    var webView: WKWebView?

    override func loadView() {
        super.loadView()

        self.webView = WKWebView()
        self.view = self.webView!
    }

    override func viewDidLoad() {
        super.viewDidLoad()

        var url = NSURL(string:"http://www.kinderas.com/")
        var req = NSURLRequest(URL:url)
        self.webView!.loadRequest(req)
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
    }

}
Run Code Online (Sandbox Code Playgroud)


stk*_*stk 1

您必须使用 WKWebView,它在 iOS8 的“WebKit”框架中提供,以获得加速。如果需要向后兼容,则必须使用 iOS7 及更早版本的 UIWebView。

我设置了一些代码来为新的 WKWebView 提供 UIViewController 框架。可以通过 cocoapods 安装。看看这里:

STKWebKitViewController on github