Swift如何為網(wǎng)頁承載頁面添加更多功能詳解
前言
接上一篇文章,我們在設(shè)置中心通常會跳轉(zhuǎn)到某一個網(wǎng)頁承載頁面,而通常我們會添加一些功能來提升他的體驗。
1.添加菊花加載的效果
2.添加跳轉(zhuǎn)到Safari的功能
3.添加復(fù)制鏈接的功能
4.添加分享網(wǎng)頁的功能
首先,以WebViewController為例,我們要創(chuàng)建一個UIWebView;然后創(chuàng)建了三個功能按鈕在左側(cè)、一個關(guān)閉頁面的按鈕在右側(cè),并且為他們分別綁定;加載按鈕的顯示和隱藏直接通過代碼實現(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() }
一、添加菊花加載的效果
加載按鈕需要在頁面加載時立刻出現(xiàn)在正中央,并且開始旋轉(zhuǎn)指導(dǎo)頁面成功加載后隱藏。
先加在頁面加載時立刻出現(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),當加載完成后立刻隱藏并且停止菊花旋轉(zhuǎn),代碼如下:
func webViewDidFinishLoad(_ webView: UIWebView) { print("web load finish") self.spinner.stopAnimating() }
二、添加跳轉(zhuǎn)到Safari的功能
初始化時已經(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,我們可以將標題和鏈接同時復(fù)制,代碼如下:
@objc func toCopy(){ print("to copy") //就這兩句話就實現(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)頁的標題、鏈接、頭圖,代碼如下:
@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") }) }
一個特性三個功能是不是很簡單?當然你需要再添加一個關(guān)閉按鈕。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對我們的支持。
上一篇:Swift實現(xiàn)監(jiān)聽鍵盤通知及一些處理詳解
欄 目:Swift
下一篇:Swift 4中一些實用的數(shù)組技巧小結(jié)
本文標題:Swift如何為網(wǎng)頁承載頁面添加更多功能詳解
本文地址:http://mengdiqiu.com.cn/a1/Swift/11955.html
您可能感興趣的文章


閱讀排行
本欄相關(guān)
- 01-11Swift利用Decodable解析JSON的一個小問題
- 01-11swift中defer幾個簡單的使用場景詳解
- 01-11Swift中初始化init的方法小結(jié)
- 01-11Swift中defer關(guān)鍵字推遲執(zhí)行示例詳解
- 01-11Swift利用純代碼實現(xiàn)時鐘效果實例代碼
- 01-11Swift中定義單例的方法實例
- 01-11Swift中排序算法的簡單取舍詳解
- 01-11Swift Json實例詳細解析
- 01-11Swift如何為設(shè)置中心添加常用功能
- 01-11Swift利用指紋識別或面部識別為應(yīng)用添
隨機閱讀
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10delphi制作wav文件的方法
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 04-02jquery與jsp,用jquery
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-10C#中split用法實例總結(jié)
- 01-11ajax實現(xiàn)頁面的局部加載
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置