Ios WKWebView与UIWebView

Ios WKWebView与UIWebView,ios,uiwebview,ios10,ios11,wkwebview,Ios,Uiwebview,Ios10,Ios11,Wkwebview,我有一个部署目标版本为iOS 10的应用程序/项目 我曾使用过UIWebView,但现在已被弃用,取而代之的是WKWebView。因此,我想在我的项目中也用WKWebView替换UIWebView 它迫使我要么使用UIWebView(使用iOS 10),要么将部署目标更改为iOS 11 我无法更改部署目标,但作为一个中间件解决方案,我添加了对这两个目标的代码(编程)支持。我的意思是,如果用户的设备操作系统是iOS 11(或更高版本),则使用WKWebView,否则使用UIWebView(对于iO

我有一个部署目标版本为iOS 10的应用程序/项目

我曾使用过
UIWebView
,但现在已被弃用,取而代之的是
WKWebView
。因此,我想在我的项目中也用WKWebView替换UIWebView

它迫使我要么使用
UIWebView
(使用iOS 10),要么将部署目标更改为iOS 11

我无法更改部署目标,但作为一个中间件解决方案,我添加了对这两个目标的代码(编程)支持。我的意思是,如果用户的设备操作系统是iOS 11(或更高版本),则使用
WKWebView
,否则使用
UIWebView
(对于iOS 10或更低版本)

问题声明:情节提要的视图控制器不支持这两个版本,我的意思是,在情节提要中,如果我将视图控制器的部署目标设置为iOS 11,那么应用程序将在iOS 10中崩溃(显然应该如此),如果我将视图控制器的部署目标设置为iOS 10,那么情节提要不允许我构建项目

对于iOS 10,
WKWebView
向我显示此错误:

问题:如何制作故事板(视图控制器),以便在iOS 11上使用
WKWebView
,在iOS 10上使用
UIWebView
?story board(视图控制器)中是否有任何配置设置或选项允许我添加两个接口插座?

您只需通过代码创建并添加
WKWebView

如果您希望在故事板中为布局目的使用视觉表示,下面是一种方法

在情节提要的视图控制器中添加标准的
UIView
。这将充当web视图的“持有者”。将其连接到一个
IBOutlet
,然后在
viewDidLoad
中添加一个
WKWebView
的实例作为该“holder”视图的子视图


在IB/Storyboard中,您有什么具体的尝试吗?如果没有,我只需要使用一个“占位符”UIView,并在
viewDidLoad
中将其替换为
WKWebView
@DonMag我可以用UIViewWebview(UIWebView到WKWebView)来做吗?怎么用?你试过吗?^这是你的答案。不必更改部署目标,也不必使用
if#available(iOS,10*){}
等,这实际上可以提高webView的性能,特别是在使用大量javascript的情况下。不要忘了在ViewController文件顶部的
导入WebKit
。我在为iOS>=9构建的项目中使用了WKWebView
class MyViewController: UIViewController, WKNavigationDelegate {

    // standard UIView, added in Storyboard
    @IBOutlet weak var webViewHolder: UIView!

    // instance of WKWebView
    let wkWebView: WKWebView = {
        let v = WKWebView()
        v.translatesAutoresizingMaskIntoConstraints = false
        return v
    }()

    override func viewDidLoad() {

        super.viewDidLoad()

        // add the WKWebView to the "holder" UIView
        webViewHolder.addSubview(wkWebView)

        // pin to all 4 edges
        wkWebView.topAnchor.constraint(equalTo: webViewHolder.topAnchor, constant: 0.0).isActive = true
        wkWebView.bottomAnchor.constraint(equalTo: webViewHolder.bottomAnchor, constant: 0.0).isActive = true
        wkWebView.leadingAnchor.constraint(equalTo: webViewHolder.leadingAnchor, constant: 0.0).isActive = true
        wkWebView.trailingAnchor.constraint(equalTo: webViewHolder.trailingAnchor, constant: 0.0).isActive = true

        // load a URL into the WKWebView
        if let url = URL(string: "https://google.com") {
            wkWebView.load(URLRequest(url: url))
        }

        // from here on out, use wkWebView just as if you had added it in your storyboard

    }

}