Как открыть любой URL-адрес, кликнутый в моем приложении iOS в браузере приложения? - PullRequest
0 голосов
/ 16 октября 2018

Как я могу установить правило так, чтобы, когда мой пользователь нажимал любую веб-ссылку в моем приложении, она открывалась в браузере внутри приложения вместо Safari?

Контекст : я создаю приложение, в котором есть несколько мест, где ссылки либо встроены мной, либо загружаются через различные взаимодействия с пользователем, например, ссылку, ведущую на страницу, котораядома другая ссылка.Я хочу убедиться, что пользователь редко покидает мое приложение и, следовательно, хочет открыть все внешние веб-ссылки в уже разработанном браузере внутри приложения

Target Build: iOS 11. Среда / Язык:Свифт 4

Ответы [ 2 ]

0 голосов
/ 11 ноября 2018

Простое решение с использованием SFSafariViewController , которое доступно в отдельном пакете

import SafariServices

Swift 4, iOS 9.0 +

let url = URL(string: "your URL here")
let vc = SFSafariViewController(url: url)
present(vc, animated: true)

Есливам нужно больше контроля - используйте параметр Configuration ( Swift 4, iOS 11.0 + ):

Пример:

let config = SFSafariViewController.Configuration()
config.entersReaderIfAvailable = true

let url = URL(string: "your URL here")
let vc = SFSafariViewController(url: url, configuration: config)
present(vc, animated: true)
0 голосов
/ 16 октября 2018

... он открывается в браузере приложения вместо Safari?

В этом случае вам потребуется собственный WebView.Вот краткий фрагмент простого веб-представления внутри контроллера:

import UIKit
import WebKit

/// The controller for handling webviews.
class WebViewController: UIViewController {

    // MARK: - Properties
    internal lazy var button_Close: UIButton = {
        let button = UIButton(type: .custom)
        button.setImage(.close, for: .normal)
        button.imageEdgeInsets = UIEdgeInsets.init(top: 0, left: -30, bottom: 0, right: 0)
        button.addTarget(self, action: #selector(back(_:)), for: .touchUpInside)
        return button
    }()

    public var urlString: String! {
        didSet {
            if let url = URL(string: urlString) {
                let urlRequest = URLRequest(url:url)
                self.webView.load(urlRequest)
            }
        }
    }

    private lazy var webView: WKWebView = {
        let webView = WKWebView()
        webView.navigationDelegate = self
        return webView
    }()

    // MARK: - Functions
    // MARK: Overrides

    override func viewDidLoad() {
        super.viewDidLoad()

        let barButton = UIBarButtonItem(customView: self.button_Close)
        self.button_Close.frame = CGRect(x: 0, y: 0, width: 55.0, height: 44.0)
        let negativeSpacer = UIBarButtonItem(barButtonSystemItem: UIBarButtonItem.SystemItem.fixedSpace, target: nil, action: nil)
        if #available(iOS 11.0, *) {
            negativeSpacer.width = -30
        }
        self.navigationItem.leftBarButtonItems = [negativeSpacer, barButton]

        self.view.addSubview(self.webView)
        self.webView.snp.makeConstraints {
            $0.edges.equalToSuperview()
        }
    }

    @objc func back(_ sender: Any) {
        self.dismiss()
    }
}

extension WebViewController: WKNavigationDelegate {
    func webView(_ webView: WKWebView, didStartProvisionalNavigation navigation: WKNavigation!) {
        // Show here a HUD or any loader
    }

    func webView(_ webView: WKWebView, didFinish navigation: WKNavigation!) {
        // Dismiss your HUD
    }
}

и представление такого веб-элемента управления, например, так (передача URL-строки):

let webViewVC = WebViewController()
webViewVC.urlString = "https://www.glennvon.com/"
let navCon = UINavigationController(rootViewController: webViewVC)
self.navigationController?.present(navCon, animated: true, completion: nil)

Если вы используете раскадровку,затем просто перетащите веб-просмотр в свой контроллер и настройте делегата.Это должно помочь вам:)

...