Ios WKWebView与UIWebView
我有一个部署目标版本为iOS 10的应用程序/项目 我曾使用过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
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
}
}