日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

ios开发跳转safari_iOS 跳转网页的四种方法

發布時間:2025/3/15 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 ios开发跳转safari_iOS 跳转网页的四种方法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

跳轉界面 push 展示網頁

1.Safari :

openURL:自帶很多功能 (進度條,刷新,前進,倒退..)就是打開了一個瀏覽器,跳出自己的應用

2.UIWebView:

沒有功能,在當前應用中打開網頁,自己去實現某些功能,但不能實現進度條功能(有些軟件做了假進度條,故意卡到70%不動,加載完成前秒到100%)

3.SFSafariViewController:

iOS9+ 專門用來展示網頁 需求:既想要在當前應用展示網頁,又想要safari功能

需要導入#import 框架

#pragma mark - UICollectionViewDelegate

- (void)collectionView:(UICollectionView *)collectionView didSelectItemAtIndexPath:(NSIndexPath *)indexPath{ // 小盒子的點擊事件

BQLog(@"%@",indexPath);

// 跳轉界面 push 展示網頁

/*

1.Safari openURL:自帶很多功能 (進度條,刷新,前進,倒退..)就是打開了一個瀏覽器,跳出自己的應用

2.UIWebView:沒有功能,在當前應用中打開網頁,自己去實現某些功能,但不能實現進度條功能

3.SFSafariViewController:iOS9+ 專門用來展示網頁 需求:既想要在當前應用展示網頁,又想要safari功能

需要導入#import 框架

4.WKWebView:iOS8+ (UIWebView升級版本)添加功能:1)監聽進度條 2)緩存

*/

BQSquareItem *item = self.squareItems[indexPath.row];

if (![item.url containsString:@"http"]) {

return;

}

SFSafariViewController *safariVc = [[SFSafariViewController alloc] initWithURL:[NSURL URLWithString:item.url]];

// safariVc.delegate = self;

// self.navigationController.navigationBarHidden = YES;

// [self.navigationController pushViewController:safariVc animated:YES];

[self presentViewController:safariVc animated:YES completion:nil]; // 推薦使用modal自動處理 而不是push

}

4.WKWebView:

iOS8+ (UIWebView升級版本)添加功能:1)監聽進度條 2)緩存

需要手動導入WebKit框架 編譯器默認不會導入

- (void)viewDidLoad {

[super viewDidLoad];

// 添加WebView

WKWebView *webView = [[WKWebView alloc] init];

_webView = webView;

[self.contentView addSubview:webView];

// 加載網頁

NSURLRequest *request = [NSURLRequest requestWithURL:self.url];

[webView loadRequest:request];

// KVO監聽屬性改變

/*

KVO使用:

addObserver:觀察者

forKeyPath:觀察webview哪個屬性

options:NSKeyValueObservingOptionNew觀察新值改變

注意點:對象銷毀前 一定要記得移除 -dealloc

*/

[webView addObserver:self forKeyPath:@"canGoBack" options:NSKeyValueObservingOptionNew context:nil];

[webView addObserver:self forKeyPath:@"canGoForward" options:NSKeyValueObservingOptionNew context:nil];

[webView addObserver:self forKeyPath:@"title" options:NSKeyValueObservingOptionNew context:nil];

// 進度條

[webView addObserver:self forKeyPath:@"estimatedProgress" options:NSKeyValueObservingOptionNew context:nil];

}

- (void)viewDidLayoutSubviews{

[super viewDidLayoutSubviews];

_webView.frame = self.contentView.bounds;

}

#pragma mark - KVO

// 只要觀察者有新值改變就會調用

- (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context{

self.backItem.enabled = self.webView.canGoBack;

self.forwardItem.enabled = self.webView.canGoForward;

self.title = self.webView.title;

self.progressView.progress = self.webView.estimatedProgress;

self.progressView.hidden = self.webView.estimatedProgress>=1;

}

- (void)dealloc {

[self.webView removeObserver:self forKeyPath:@"canGoBack"];

[self.webView removeObserver:self forKeyPath:@"canGoForward"];

[self.webView removeObserver:self forKeyPath:@"title"];

[self.webView removeObserver:self forKeyPath:@"estimatedProgress"];

}

#pragma mark - 按鈕的點擊事件

- (IBAction)goBack:(id)sender { // 回退

[self.webView goBack];

}

- (IBAction)goForward:(id)sender { // 前進

[self.webView goForward];

}

- (IBAction)reload:(id)sender { //刷新

[self.webView reload];

}

總結

以上是生活随笔為你收集整理的ios开发跳转safari_iOS 跳转网页的四种方法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。