为网页承载页面添加更多功能

OneSwift - iOS Tips Based On Swiftgit

接上一篇文章,咱们在设置中心一般会跳转到某一个网页承载页面,而一般咱们会添加一些功能来提高他的体验。github

1.添加菊花加载的效果web

2.添加跳转到Safari的功能浏览器

3.添加复制连接的功能bash

4.添加分享网页的功能app

首先,以WebViewController为例,咱们要建立一个UIWebView;而后建立了三个功能按钮在左侧、一个关闭页面的按钮在右侧,而且为他们分别绑定;加载按钮的显示和隐藏直接经过代码实现。头部状态的代码以下:async

class WebViewController: UIViewController,UIWebViewDelegate{
    let spinner = UIActivityIndicatorView()
    @IBOutlet weak var WebView: UIWebView!

    @IBAction func CloseAction(_ sender: Any) {
        self.dismiss(animated: true, completion: nil)
    }

    @IBAction func SafariAction(_ sender: Any) {
        self.toSafari()
    }

    @IBAction func CopyAction(_ sender: Any) {
        self.toCopy()
    }

    @IBAction func MoreAction(_ sender: Any) {
        self.toMore()
    }


复制代码

1、添加菊花加载的效果

加载按钮须要在页面加载时马上出如今正中央,而且开始旋转指导页面成功加载后隐藏。ide

先加在页面加载时马上出现加载菊花,代码以下:函数

override func viewDidLoad() {
        super.viewDidLoad()

        //菊花按钮
        spinner.activityIndicatorViewStyle = .gray
        spinner.center = view.center
        spinner.hidesWhenStopped = true
        view.addSubview(spinner)
        spinner.startAnimating()

        self.loadWeb()
        // Do any additional setup after loading the view.
}
复制代码

以后webViewDidFinishLoad检测了页面加载的状态,当加载完成后马上隐藏而且中止菊花旋转,代码以下:ui

func webViewDidFinishLoad(_ webView: UIWebView) {
        print("web load finish")
        self.spinner.stopAnimating()
    }
复制代码

2、添加跳转到Safari的功能

初始化时已经绑定了打开浏览器的函数toSafari,打开浏览器的操做就很简单了:

@objc func toSafari(){
        print("to safari")

        if let url = NSURL(string:self.url)  {

            UIApplication.shared.open(url as URL, options: [:], completionHandler: nil)
        }

}
复制代码

3、添加复制连接的功能

复制网页信息的方法toCopy,咱们能够将标题和连接同时复制,代码以下:

@objc func toCopy(){
        print("to copy")
        //就这两句话就实现了
        let paste = UIPasteboard.general
        let str = self.urlTitle+":"+self.url
        print(str)
        paste.string = str
        let alertController = UIAlertController(title: NSLocalizedString("Copy Success!",comment: "Copy Success!"),message: nil,preferredStyle: .alert)
        //显示提示框
        self.present(alertController, animated: true, completion: nil)
        //两秒钟后自动消失
        DispatchQueue.main.asyncAfter(deadline: DispatchTime.now() + 2) {
            self.presentedViewController?.dismiss(animated: false, completion: nil)
        }


}
复制代码

4、添加分享网页的功能

分享网页的方法toMore,采用了相似于分享应用的方式,这是这里的内容咱们改成网页的信息,好比网页的标题、连接、头图,代码以下:

@objc func toMore(){
       print("to more")

       let shareVC:UIActivityViewController = UIActivityViewController(activityItems: [self.urlTitle,self.urlImage,self.url], applicationActivities: nil)
       self.present(shareVC, animated: true, completion: {
           print("more success")
       })
   }
复制代码

一个特性三个功能是否是很简单?固然你须要再添加一个关闭按钮。

GitHub:OneSwift - iOS Tips Based On Swift

微博:xDEHANG

相关文章
相关标签/搜索