Swift如何为网页承载页面添加更多功能详解
前言
接上一篇文章,我们在设置中心通常会跳转到某一个网页承载页面,而通常我们会添加一些功能来提升他的体验。
1.添加菊花加载的效果
2.添加跳转到Safari的功能
3.添加复制链接的功能
4.添加分享网页的功能
首先,以WebViewController为例,我们要创建一个UIWebView;然后创建了三个功能按钮在左侧、一个关闭页面的按钮在右侧,并且为他们分别绑定;加载按钮的显示和隐藏直接通过代码实现。头部状态的代码如下:
classWebViewController:UIViewController,UIWebViewDelegate{ letspinner=UIActivityIndicatorView() @IBOutletweakvarWebView:UIWebView! @IBActionfuncCloseAction(_sender:Any){ self.dismiss(animated:true,completion:nil) } @IBActionfuncSafariAction(_sender:Any){ self.toSafari() } @IBActionfuncCopyAction(_sender:Any){ self.toCopy() } @IBActionfuncMoreAction(_sender:Any){ self.toMore() }
一、添加菊花加载的效果
加载按钮需要在页面加载时立刻出现在正中央,并且开始旋转指导页面成功加载后隐藏。
先加在页面加载时立刻出现加载菊花,代码如下:
overridefuncviewDidLoad(){ super.viewDidLoad() //菊花按钮 spinner.activityIndicatorViewStyle=.gray spinner.center=view.center spinner.hidesWhenStopped=true view.addSubview(spinner) spinner.startAnimating() self.loadWeb() //Doanyadditionalsetupafterloadingtheview. }
之后webViewDidFinishLoad检测了页面加载的状态,当加载完成后立刻隐藏并且停止菊花旋转,代码如下:
funcwebViewDidFinishLoad(_webView:UIWebView){ print("webloadfinish") self.spinner.stopAnimating() }
二、添加跳转到Safari的功能
初始化时已经绑定了打开浏览器的函数toSafari,打开浏览器的操作就很简单了:
@objcfunctoSafari(){ print("tosafari") ifleturl=NSURL(string:self.url){ UIApplication.shared.open(urlasURL,options:[:],completionHandler:nil) } }
三、添加复制链接的功能
复制网页信息的方法toCopy,我们可以将标题和链接同时复制,代码如下:
@objcfunctoCopy(){ print("tocopy") //就这两句话就实现了 letpaste=UIPasteboard.general letstr=self.urlTitle+":"+self.url print(str) paste.string=str letalertController=UIAlertController(title:NSLocalizedString("CopySuccess!",comment:"CopySuccess!"),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) } }
四、添加分享网页的功能
分享网页的方法toMore,采用了类似于分享应用的方式,这是这里的内容我们改为网页的信息,比如网页的标题、链接、头图,代码如下:
@objcfunctoMore(){ print("tomore") letshareVC:UIActivityViewController=UIActivityViewController(activityItems:[self.urlTitle,self.urlImage,self.url],applicationActivities:nil) self.present(shareVC,animated:true,completion:{ print("moresuccess") }) }
一个特性三个功能是不是很简单?当然你需要再添加一个关闭按钮。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对毛票票的支持。