分享一個網(wǎng)頁瀏覽器(Swift&Objective-C版本)

老規(guī)矩,先看效果圖。
QQ20170828-113431-HD-iloveimg-compressed.gif
關(guān)于怎么獲取WKWebView頁面title和加載進度值,大家可以參考我之前的文章;

接下來,說一下怎么實現(xiàn)點擊返回按鈕來返回上一Controller或者網(wǎng)頁記錄,以及關(guān)閉按鈕的隱藏和出現(xiàn)。

第一步,創(chuàng)建觀察者,監(jiān)聽WKWebViewcanGoBack值變化,如下
[self.wkWebview addObserver:self forKeyPath:@"canGoBack" options:NSKeyValueObservingOptionNew context:NULL];
第二步,實現(xiàn)kvo的監(jiān)聽方法,如下,
#pragma mark KVO的監(jiān)聽代理
- (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context {

    //是否可以返回
    if ([keyPath isEqualToString:@"canGoBack"])
    {
        if (object == self.wkWebview)
        {
        }
    }
    else
    {
        [super observeValueForKeyPath:keyPath ofObject:object change:change context:context];
    }
}

第三步,創(chuàng)建返回按鈕和關(guān)閉按鈕,實現(xiàn)對應(yīng)的方法,判斷返回按鈕執(zhí)行的是pop操作,還是返回上一個網(wǎng)頁記錄,如下
#pragma mark 設(shè)置BarButtonItem
- (void)setBarButtonItem
{

    //設(shè)置距離左邊屏幕的寬度距離
    self.leftBarButton = [[UIBarButtonItem alloc]initWithImage:[UIImage imageNamed:@"back_item"] style:UIBarButtonItemStylePlain target:self action:@selector(selectedToBack)];
    self.negativeSpacer = [[UIBarButtonItem alloc]   initWithBarButtonSystemItem:UIBarButtonSystemItemFixedSpace   target:nil action:nil];
    self.negativeSpacer.width = -5;

    //設(shè)置關(guān)閉按鈕,以及關(guān)閉按鈕和返回按鈕之間的距離
    self.leftBarButtonSecond = [[UIBarButtonItem alloc]initWithImage:[UIImage imageNamed:@"close_item"] style:UIBarButtonItemStylePlain target:self action:@selector(selectedToClose)];
    self.leftBarButtonSecond.imageInsets = UIEdgeInsetsMake(0, -20, 0, 20);
    self.navigationItem.leftBarButtonItems = @[self.negativeSpacer,self.leftBarButton];


    //設(shè)置刷新按妞
    UIBarButtonItem *reloadItem = [[UIBarButtonItem alloc]initWithImage:[UIImage imageNamed:@"reload_item"] style:UIBarButtonItemStylePlain target:self action:@selector(selectedToReloadData)];
    self.navigationItem.rightBarButtonItem = reloadItem;

}
#pragma mark 關(guān)閉并上一界面
- (void)selectedToClose
{
    [self.navigationController popViewControllerAnimated:YES];
}

#pragma mark 返回上一個網(wǎng)頁還是上一個Controller
- (void)selectedToBack
{
    if (self.wkWebview.canGoBack == 1)
    {
        [self.wkWebview goBack];
    }
    else
    {
        [self.navigationController popViewControllerAnimated:YES];
    }
}

#pragma mark reload
- (void)selectedToReloadData
{
    [self.wkWebview reload];
}
第四步,在KVO監(jiān)聽方法中來判斷是否顯示關(guān)閉按鈕,如下
if ([keyPath isEqualToString:@"canGoBack"])
    {
        if (object == self.wkWebview)
        {
            if (self.wkWebview.canGoBack == 1)
            {
                self.navigationItem.leftBarButtonItems = @[self.negativeSpacer,self.leftBarButton,self.leftBarButtonSecond];
            }
            else
            {
                self.navigationItem.leftBarButtonItems = @[self.negativeSpacer,self.leftBarButton];
            }
        }
        else
        {
            [super observeValueForKeyPath:keyPath ofObject:object change:change context:context];
        }
    }
第五步,觀察者的添加和移除是成對出現(xiàn)的,所以別忘了移除觀察者。
#pragma mark 移除觀察者
- (void)dealloc
{
    [self.wkWebview removeObserver:self forKeyPath:@"estimatedProgress"];
    [self.wkWebview removeObserver:self forKeyPath:@"canGoBack"];
    [self.wkWebview removeObserver:self forKeyPath:@"title"];
}
說明:

1.添加
self.negativeSpacer = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemFixedSpace target:nil action:nil];
self.negativeSpacer.width = -5;
的作用就是為了調(diào)整關(guān)閉按鈕與返回屏幕之間的距離
2.只有當(dāng)關(guān)閉按鈕是Image類型,才能通過self.leftBarButtonSecond.imageInsets = UIEdgeInsetsMake(0, -20, 0, 20);來調(diào)整返回按鈕與關(guān)閉按鈕之間的距離。如果是title類型的,則可能會沒有作用。

完整的demo,大家可以去我的Github下載Objective-C版本Swift版本,
代碼肯定會有不足的地方,還希望大家多多指教。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容