UIWebView繼承與UIView,所以,其初始化方法和通常的view同樣,經過alloc和init進行初始化,其加載數據的方式有三種:html
第一種:java
- (void)loadRequest:(NSURLRequest *)request;web
這是加載網頁最經常使用的一種方式,經過一個網頁URL來進行加載,這個URL能夠是遠程的也能夠是本地的,例如我加載百度的主頁:
ui
?編碼
1
2
3
|
UIWebView * view = [[UIWebView alloc]initWithFrame:self.view.frame];
[view loadRequest:[NSURLRequest requestWithURL:[NSURL URLWithString:@
"http://www.baidu.com"
]]];
[self.view addSubview:view];
|
會獲得以下的效果:
atom
第二種:lua
- (void)loadHTMLString:(NSString *)string baseURL:(NSURL *)baseURL;spa
這個方法須要將httml文件讀取爲字符串,其中baseURL是咱們本身設置的一個路徑,用於尋找html文件中引用的圖片等素材。.net
第三種:代理
- (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以後纔有的,經過他們能夠設置更加有趣的web體驗
@property (nonatomic) UIWebPaginationMode paginationMode NS_AVAILABLE_IOS(7_0);
這個屬性用來設置一種模式,當網頁的大小超出view時,將網頁以翻頁的效果展現,枚舉以下:
1
2
3
4
5
6
7
|
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);
獲取分頁數
- (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;
加載失敗時調用的方法