На даний момент я відкриваю посилання в моєму додатку в WebView
, але шукаю можливість відкрити посилання замість цього в Safari .
На даний момент я відкриваю посилання в моєму додатку в WebView
, але шукаю можливість відкрити посилання замість цього в Safari .
Відповіді:
Це не "запекло в Свіфті", але ви можете використовувати стандартні UIKit
методи для цього. Погляньте на (застарілі) та .openUrl(_:)
open(_:options:completionHandler:)
Swift 4 + Swift 5 (iOS 10 і вище)
guard let url = URL(string: "https://stackoverflow.com") else { return }
UIApplication.shared.open(url)
Swift 3 (iOS 9 і нижче)
guard let url = URL(string: "https://stackoverflow.com") else { return }
UIApplication.shared.openURL(url)
Швидкий 2.2
guard let url = URL(string: "https://stackoverflow.com") else { return }
UIApplication.sharedApplication().openURL(url)
Нове в iOS 9 і новіших версіях ви можете представити користувачеві SFSafariViewController
(див. Документацію тут ). В основному, ви отримуєте всі переваги від того, щоб відправити користувача в Safari, не змушуючи його залишати ваш додаток. Щоб використовувати новий SFSafariViewController, просто:
import SafariServices
а десь у обробнику події представити користувачеві такий контролер перегляду сафарі:
let svc = SFSafariViewController(url: url)
present(svc, animated: true, completion: nil)
Вид сафарі буде виглядати приблизно так:
sharedApplication
ресурсу в розширенні програми заборонено. Докладніше: developer.apple.com/library/archive/documentation/General/…
ОНОВЛЕНО для Swift 4: (кредит до Марко Вебера)
if let requestUrl = NSURL(string: "http://www.iSecurityPlus.com") {
UIApplication.shared.openURL(requestUrl as URL)
}
АБО переходьте з більш швидким стилем, використовуючи guard
:
guard let requestUrl = NSURL(string: "http://www.iSecurityPlus.com") else {
return
}
UIApplication.shared.openURL(requestUrl as URL)
Швидкий 3:
Ви можете перевірити NSURL як необов'язково неявно:
if let requestUrl = NSURL(string: "http://www.iSecurityPlus.com") {
UIApplication.sharedApplication().openURL(requestUrl)
}
if let requestUrl = NSURL(string: "http://www.iSecurityPlus.com") { UIApplication.shared.openURL(requestUrl as URL) }
Swift 3 та IOS 10.2
UIApplication.shared.open(URL(string: "http://www.stackoverflow.com")!, options: [:], completionHandler: nil)
Swift 3 та IOS 10.2
оскільки iOS 10 ви повинні використовувати:
guard let url = URL(string: linkUrlString) else {
return
}
if #available(iOS 10.0, *) {
UIApplication.shared.open(url, options: [:], completionHandler: nil)
} else {
UIApplication.shared.openURL(url)
}
Швидкий 5
Swift 5: Перевірте, canOpneURL
чи є дійсним, тоді він відкритий.
guard let url = URL(string: "https://iosdevcenters.blogspot.com/") else {
return
}
if UIApplication.shared.canOpenURL(url) {
UIApplication.shared.open(url, options: [:], completionHandler: nil)
}
У Swift 1.2:
@IBAction func openLink {
let pth = "http://www.google.com"
if let url = NSURL(string: pth){
UIApplication.sharedApplication().openURL(url)
}
IOS 11.2 Swift 3.1-4
let webView = WKWebView()
override func viewDidLoad() {
super.viewDidLoad()
guard let url = URL(string: "https://www.google.com") else { return }
webView.frame = view.bounds
webView.navigationDelegate = self
webView.load(URLRequest(url: url))
webView.autoresizingMask = [.flexibleWidth,.flexibleHeight]
view.addSubview(webView)
}
func webView(_ webView: WKWebView, decidePolicyFor navigationAction: WKNavigationAction, decisionHandler: @escaping (WKNavigationActionPolicy) -> Void) {
if navigationAction.navigationType == .linkActivated {
if let url = navigationAction.request.url,
let host = url.host, !host.hasPrefix("www.google.com"),
UIApplication.shared.canOpenURL(url) {
UIApplication.shared.open(url)
print(url)
print("Redirected to browser. No need to open it locally")
decisionHandler(.cancel)
} else {
print("Open it locally")
decisionHandler(.allow)
}
} else {
print("not a user click")
decisionHandler(.allow)
}
}