作者:朝朝宝宝 | 来源:互联网 | 2023-01-12 17:30
我有一个部署目标版本的应用/项目 - iOS 10.
我曾经使用过UIWebView
,现在已被弃用并被替换为WKWebView
.所以,我想在我的项目中用UIWView替换WKWebView.
它迫使我使用UIWebView
(使用iOS 10)或将部署目标更改为iOS 11.
我不能改变部署目标,但作为中间件解决方案,我添加了代码(编程)支持.我的意思是,如果用户的设备操作系统是iOS 11(或更高版本),则使用WKWebView
其他用途UIWebView
(适用于iOS 10或更低版本).
问题陈述:故事板的视图控制器不支持这两个版本,我的意思是,在故事板中,如果我将View控制器的部署目标设置为iOS 11,那么应用程序在iOS 10中崩溃(显而易见)应该崩溃,如果我将视图控制器的部署目标设置为iOS 10,那么storyboard不允许我构建项目.
对于iOS 10,WKWebView
向我显示此错误:Xcode 9 GM - WKWebView NSCoding支持在以前的版本中被破坏
问题:如何使故事板(视图控制器)WKWebView
用于iOS 11和UIWebView
iOS 10?故事板(视图控制器)中是否有任何配置设置或选项可以允许我添加两个接口插座?
1> DonMag..:
你可以简单地创建并添加WKWebView
通过代码.
如果您想在Storyboard中使用可视化表示进行布局,可以使用以下方法.
UIView
在Storyboard中的视图控制器中添加标准.这将充当您的Web视图的"持有者".将它连接到a IBOutlet
,然后viewDidLoad
添加一个实例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
}
}