iOS中UIWebView的使用詳解

一、初始化與三種加載方式
UIWebView繼承與UIView,因此,其初始化方法和一般的view一樣,通過alloc和init進行初始化,其加載數據的方式有三種:
第一種:

  • (void)loadRequest:(NSURLRequest *)request;
    這是加載網頁最常用的一種方式,通過一個網頁URL來進行加載,這個URL可以是遠程的也可以是本地的。
    第二種:
  • (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;
@property (nonatomic, readonly, retain) UIScrollView *scrollView;
@property (nonatomic, readonly, retain) NSURLRequest *request;

  • (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);
    設置某些數據變為鏈接形式,這個枚舉可以設置如電話號,地址,郵箱等轉化為鏈接

    typedef NS_OPTIONS(NSUInteger, UIDataDetectorTypes) {
    UIDataDetectorTypePhoneNumber = 1 << 0, // Phone number detection
    UIDataDetectorTypeLink = 1 << 1, // URL detection
    UIDataDetectorTypeAddress NS_ENUM_AVAILABLE_IOS(4_0) = 1 << 2, // Street address detection
    UIDataDetectorTypeCalendarEvent NS_ENUM_AVAILABLE_IOS(4_0) = 1 << 3, // Event detection

    UIDataDetectorTypeNone = 0, // No detection at all
    UIDataDetectorTypeAll = NSUIntegerMax // All types
    } __TVOS_PROHIBITED;

    @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) UIWebPaginationBreakingMode paginationBreakingMode NS_AVAILABLE_IOS(7_0);
這個屬性???。枚舉如下:(
typedef NS_ENUM(NSInteger, UIWebPaginationBreakingMode) {
UIWebPaginationBreakingModePage,
UIWebPaginationBreakingModeColumn
} __TVOS_PROHIBITED;)
@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);
獲取分頁數

四、iOS9的一些新特性
@property (nonatomic) BOOL allowsPictureInPictureMediaPlayback NS_AVAILABLE_IOS(9_0);
???
@property (nonatomic) BOOL allowsLinkPreview NS_AVAILABLE_IOS(9_0); // default is NO
???

五、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;
    加載失敗時調用的方法

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容