IOS中UIWebView的使用詳解
一、初始化與三種加載方式
UIWebView繼承與UIView,因此,其初始化方法和一般的view一樣,通過alloc和init進行初始化,其加載數(shù)據(jù)的方式有三種:
第一種:
- (void)loadRequest:(NSURLRequest *)request;
這是加載網(wǎng)頁最常用的一種方式,通過一個網(wǎng)頁URL來進行加載,這個URL可以是遠程的也可以是本地的,例如我加載百度的主頁:
UIWebView * view = [[UIWebView alloc]initWithFrame:self.view.frame]; [view loadRequest:[NSURLRequest requestWithURL:[NSURL URLWithString:@"http://www.baidu.com"]]]; [self.view addSubview:view];
會得到如下的效果:

第二種:
- (void)loadHTMLString:(NSString *)string baseURL:(NSURL *)baseURL;
這個方法需要將httml文件讀取為字符串,其中baseURL是我們自己設(shè)置的一個路徑,用于尋找html文件中引用的圖片等素材。
第三種:
- (void)loadData:(NSData *)data MIMEType:(NSString *)MIMEType textEncodingName:(NSString *)textEncodingName baseURL:(NSURL *)baseURL;
這個方式使用的比較少,但也更加自由,其中data是文件數(shù)據(jù),MIMEType是文件類型,textEncodingName是編碼類型,baseURL是素材資源路徑。
二、一些常用的屬性和變量
@property (nonatomic, assign) id <UIWebViewDelegate> delegate;
設(shè)置webView的代理
@property (nonatomic, readonly, retain) UIScrollView *scrollView;
內(nèi)置的scrollView
@property (nonatomic, readonly, retain) NSURLRequest *request;
URL請求
- (void)reload;
重新加載數(shù)據(jù)
- (void)stopLoading;
停止加載數(shù)據(jù)
- (void)goBack;
返回上一級
- (void)goForward;
跳轉(zhuǎn)下一級
@property (nonatomic, readonly, getter=canGoBack) BOOL canGoBack;
獲取能否返回上一級
@property (nonatomic, readonly, getter=canGoForward) BOOL canGoForward;
獲取能否跳轉(zhuǎn)下一級
@property (nonatomic, readonly, getter=isLoading) BOOL loading;
獲取是否正在加載數(shù)據(jù)
- (NSString *)stringByEvaluatingJavaScriptFromString:(NSString *)script;
通過javaScript操作web數(shù)據(jù)
@property (nonatomic) BOOL scalesPageToFit;
設(shè)置是否縮放到適合屏幕大小
@property (nonatomic) UIDataDetectorTypes dataDetectorTypes NS_AVAILABLE_IOS(3_0);
設(shè)置某些數(shù)據(jù)變?yōu)殒溄有问?,這個枚舉可以設(shè)置如電話號,地址,郵箱等轉(zhuǎn)化為鏈接
@property (nonatomic) BOOL allowsInlineMediaPlayback NS_AVAILABLE_IOS(4_0);
設(shè)置是否使用內(nèi)聯(lián)播放器播放視頻
@property (nonatomic) BOOL mediaPlaybackRequiresUserAction NS_AVAILABLE_IOS(4_0);
設(shè)置視頻是否自動播放
@property (nonatomic) BOOL mediaPlaybackAllowsAirPlay NS_AVAILABLE_IOS(5_0);
設(shè)置音頻播放是否支持ari play功能
@property (nonatomic) BOOL suppressesIncrementalRendering NS_AVAILABLE_IOS(6_0);
設(shè)置是否將數(shù)據(jù)加載如內(nèi)存后渲染界面
@property (nonatomic) BOOL keyboardDisplayRequiresUserAction NS_AVAILABLE_IOS(6_0);
設(shè)置用戶交互模式
三、iOS7中的一些新特性
下面這些屬性是iOS7之后才有的,通過他們可以設(shè)置更加有趣的web體驗
@property (nonatomic) UIWebPaginationMode paginationMode NS_AVAILABLE_IOS(7_0);
這個屬性用來設(shè)置一種模式,當(dāng)網(wǎng)頁的大小超出view時,將網(wǎng)頁以翻頁的效果展示,枚舉如下:
typedef NS_ENUM(NSInteger, UIWebPaginationMode) {
UIWebPaginationModeUnpaginated,//不使用翻頁效果
UIWebPaginationModeLeftToRight,//將網(wǎng)頁超出部分分頁,從左向右進行翻頁
UIWebPaginationModeTopToBottom,//將網(wǎng)頁超出部分分頁,從上向下進行翻頁
UIWebPaginationModeBottomToTop,//將網(wǎng)頁超出部分分頁,從下向上進行翻頁
UIWebPaginationModeRightToLeft//將網(wǎng)頁超出部分分頁,從右向左進行翻頁
};
@property (nonatomic) CGFloat pageLength NS_AVAILABLE_IOS(7_0);
設(shè)置每一頁的長度
@property (nonatomic) CGFloat gapBetweenPages NS_AVAILABLE_IOS(7_0);
設(shè)置每一頁的間距
@property (nonatomic, readonly) NSUInteger pageCount NS_AVAILABLE_IOS(7_0);
獲取分頁數(shù)
四、webView協(xié)議中的方法
- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType;
準(zhǔn)備加載內(nèi)容時調(diào)用的方法,通過返回值來進行是否加載的設(shè)置
- (void)webViewDidStartLoad:(UIWebView *)webView;
開始加載時調(diào)用的方法
- (void)webViewDidFinishLoad:(UIWebView *)webView;
結(jié)束加載時調(diào)用的方法
- (void)webView:(UIWebView *)webView didFailLoadWithError:(NSError *)error;
加載失敗時調(diào)用的方法
相關(guān)文章
iOS中關(guān)于Taptic-Engine震動反饋的深入解析
這篇文章主要給大家介紹了關(guān)于iOS中關(guān)于Taptic-Engine震動反饋的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-11-11
UICollectionView 實現(xiàn)圖片瀏覽效果
這篇文章主要為大家介紹了UICollectionView 實現(xiàn)圖片瀏覽效果示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-07-07

