標籤:
iOS中UIWebView的使用詳解 一、初始化與三種載入方式
UIWebView繼承與UIView,因此,其初始化方法和一般的view一樣,通過alloc和init進行初始化,其載入資料的方式有三種:
第一種:
- (void)loadRequest:(NSURLRequest *)request;
這是載入網頁最常用的一種方式,通過一個網頁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是我們自己設定的一個路徑,用於尋找html檔案中引用的圖片等素材。
第三種:
- (void)loadData:(NSData *)data MIMEType:(NSString *)MIMEType textEncodingName:(NSString *)textEncodingName baseURL:(NSURL *)baseURL;
這個方式使用的比較少,但也更加自由,其中data是檔案資料,MIMEType是檔案類型,textEncodingName是編碼類別型,baseURL是素材資源路徑。
二、一些常用的屬性和變數
@property (nonatomic, assign) id <UIWebViewDelegate> delegate;
設定webView的代理
@property (nonatomic, readonly, retain) UIScrollView *scrollView;
內建的scrollView
@property (nonatomic, readonly, retain) NSURLRequest *request;
URL請求
- (void)reload;
重新載入資料
- (void)stopLoading;
停止載入資料
- (void)goBack;
返回上一級
- (void)goForward;
跳轉下一級
@property (nonatomic, readonly, getter=canGoBack) BOOL canGoBack;
擷取能否返回上一級
@property (nonatomic, readonly, getter=canGoForward) BOOL canGoForward;
擷取能否跳轉下一級
@property (nonatomic, readonly, getter=isLoading) BOOL loading;
擷取是否正在載入資料
- (NSString *)stringByEvaluatingJavaScriptFromString:(NSString *)script;
通過javaScript操作web資料
@property (nonatomic) BOOL scalesPageToFit;
設定是否縮放到適合螢幕大小
@property (nonatomic) UIDataDetectorTypes dataDetectorTypes NS_AVAILABLE_IOS(3_0);
設定某些資料變為連結形式,這個枚舉可以設定如電話號,地址,郵箱等轉化為連結
@property (nonatomic) BOOL allowsInlineMediaPlayback NS_AVAILABLE_IOS(4_0);
設定是否使用內聯播放器播放視頻
@property (nonatomic) BOOL mediaPlaybackRequiresUserAction NS_AVAILABLE_IOS(4_0);
設定視頻是否自動播放
@property (nonatomic) BOOL mediaPlaybackAllowsAirPlay NS_AVAILABLE_IOS(5_0);
設定音頻播放是否支援ari play功能
@property (nonatomic) BOOL suppressesIncrementalRendering NS_AVAILABLE_IOS(6_0);
設定是否將資料載入如記憶體後渲染介面
@property (nonatomic) BOOL keyboardDisplayRequiresUserAction NS_AVAILABLE_IOS(6_0);
設定使用者互動模式
三、iOS7中的一些新特性
下面這些屬性是iOS7之後才有的,通過他們可以設定更加有趣的web體驗
@property (nonatomic) UIWebPaginationMode paginationMode NS_AVAILABLE_IOS(7_0);
這個屬性用來設定一種模式,當網頁的大小超出view時,將網頁以翻頁的效果展示,枚舉如下:
typedef NS_ENUM(NSInteger, UIWebPaginationMode) { UIWebPaginationModeUnpaginated,//不使用翻頁效果 UIWebPaginationModeLeftToRight,//將網頁超出部分分頁,從左向右進行翻頁 UIWebPaginationModeTopToBottom,//將網頁超出部分分頁,從上向下進行翻頁 UIWebPaginationModeBottomToTop,//將網頁超出部分分頁,從下向上進行翻頁 UIWebPaginationModeRightToLeft//將網頁超出部分分頁,從右向左進行翻頁};
@property (nonatomic) CGFloat pageLength NS_AVAILABLE_IOS(7_0);
設定每一頁的長度
@property (nonatomic) CGFloat gapBetweenPages NS_AVAILABLE_IOS(7_0);
設定每一頁的間距
@property (nonatomic, readonly) NSUInteger pageCount NS_AVAILABLE_IOS(7_0);
擷取分頁數
四、webView協議中的方法
- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType;
準備載入內容時調用的方法,通過傳回值來進行是否載入的設定
- (void)webViewDidStartLoad:(UIWebView *)webView;
開始載入時調用的方法
- (void)webViewDidFinishLoad:(UIWebView *)webView;
結束載入時調用的方法
- (void)webView:(UIWebView *)webView didFailLoadWithError:(NSError *)error;
載入失敗時調用的方法
iOS中UIWebView的使用詳解