Swift如何為網(wǎng)頁承載頁面添加更多功能詳解
前言
接上一篇文章,我們在設(shè)置中心通常會跳轉(zhuǎn)到某一個(gè)網(wǎng)頁承載頁面,而通常我們會添加一些功能來提升他的體驗(yàn)。
1.添加菊花加載的效果
2.添加跳轉(zhuǎn)到Safari的功能
3.添加復(fù)制鏈接的功能
4.添加分享網(wǎng)頁的功能
首先,以WebViewController為例,我們要?jiǎng)?chuàng)建一個(gè)UIWebView;然后創(chuàng)建了三個(gè)功能按鈕在左側(cè)、一個(gè)關(guān)閉頁面的按鈕在右側(cè),并且為他們分別綁定;加載按鈕的顯示和隱藏直接通過代碼實(shí)現(xiàn)。頭部狀態(tài)的代碼如下:
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()
}
一、添加菊花加載的效果
加載按鈕需要在頁面加載時(shí)立刻出現(xiàn)在正中央,并且開始旋轉(zhuǎn)指導(dǎo)頁面成功加載后隱藏。
先加在頁面加載時(shí)立刻出現(xiàn)加載菊花,代碼如下:
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檢測了頁面加載的狀態(tài),當(dāng)加載完成后立刻隱藏并且停止菊花旋轉(zhuǎn),代碼如下:
func webViewDidFinishLoad(_ webView: UIWebView) {
print("web load finish")
self.spinner.stopAnimating()
}
二、添加跳轉(zhuǎn)到Safari的功能
初始化時(shí)已經(jīng)綁定了打開瀏覽器的函數(shù)toSafari,打開瀏覽器的操作就很簡單了:
@objc func toSafari(){
print("to safari")
if let url = NSURL(string:self.url) {
UIApplication.shared.open(url as URL, options: [:], completionHandler: nil)
}
}
三、添加復(fù)制鏈接的功能
復(fù)制網(wǎng)頁信息的方法toCopy,我們可以將標(biāo)題和鏈接同時(shí)復(fù)制,代碼如下:
@objc func toCopy(){
print("to copy")
//就這兩句話就實(shí)現(xiàn)了
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)
}
}
四、添加分享網(wǎng)頁的功能
分享網(wǎng)頁的方法toMore,采用了類似于分享應(yīng)用的方式,這是這里的內(nèi)容我們改為網(wǎng)頁的信息,比如網(wǎng)頁的標(biāo)題、鏈接、頭圖,代碼如下:
@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")
})
}
一個(gè)特性三個(gè)功能是不是很簡單?當(dāng)然你需要再添加一個(gè)關(guān)閉按鈕。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
Swift 3.0將UILabel數(shù)字顏色設(shè)置為紅色的方法
這篇文章主要介紹了關(guān)于在Swift中將UILabel數(shù)字顏色設(shè)置為紅色的方法,文中給出了詳細(xì)的示例代碼,相信對大家具有一定的參考價(jià)值,需要的朋友們下面來一起看看吧。2017-03-03
通過Notification.Name看Swift是如何優(yōu)雅的解決String硬編碼
這篇文章主要給大家介紹了通過Notification.Name看Swift是如何優(yōu)雅的解決String硬編碼的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-08-08
詳解swift中xcworkspace多項(xiàng)目管理
給大家詳細(xì)講解了IOS開發(fā)中swift語言xcworkspace多項(xiàng)目管理的方法和介紹,一起參考一下。2017-11-11
Swift算法之棧和隊(duì)列的實(shí)現(xiàn)方法示例
Swift語言中沒有內(nèi)設(shè)的棧和隊(duì)列,很多擴(kuò)展庫中使用Generic Type來實(shí)現(xiàn)?;蚴顷?duì)列。下面這篇文章就來給大家詳細(xì)介紹了Swift算法之棧和隊(duì)列的實(shí)現(xiàn)方法,需要的朋友可以參考學(xué)習(xí),下面來一起看看吧。2017-03-03
Swift中動態(tài)調(diào)用實(shí)例方法介紹
這篇文章主要介紹了Swift中動態(tài)調(diào)用實(shí)例方法介紹,在Swift中有一類很有意思的寫法,可以讓我們不直接使用實(shí)例來調(diào)用這個(gè)實(shí)例上的方法,而是通過類型取出這個(gè)類型的某個(gè)實(shí)例方法的簽名,然后再通過傳遞實(shí)例來拿到實(shí)際需要調(diào)用的方法,需要的朋友可以參考下2015-01-01

