欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

iOS之UIWebView無(wú)法如何獲取web標(biāo)題

這篇文章將為大家詳細(xì)講解有關(guān)iOS之UIWebView無(wú)法如何獲取web標(biāo)題,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

成都創(chuàng)新互聯(lián)是專業(yè)的金臺(tái)網(wǎng)站建設(shè)公司,金臺(tái)接單;提供成都做網(wǎng)站、網(wǎng)站設(shè)計(jì),網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行金臺(tái)網(wǎng)站開發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來(lái)合作!

最近遇到了一個(gè)問(wèn)題,就是在UIWebView的代理方法里,執(zhí)行document.titlejs代碼無(wú)法獲取網(wǎng)頁(yè)標(biāo)題,代碼如下:

- (void)webViewDidFinishLoad:(UIWebView *)webView
{
  // 取加載html文件的標(biāo)題名
  NSString *title = [webView stringByEvaluatingJavaScriptFromString:@"document.title"];
}

出現(xiàn)這個(gè)問(wèn)題,我首先確定是不是代碼的問(wèn)題,經(jīng)過(guò)分析,發(fā)現(xiàn)代碼沒(méi)有改動(dòng),但這次卻無(wú)法獲取網(wǎng)頁(yè)標(biāo)題,甚是奇怪。經(jīng)過(guò)查找分析,問(wèn)題是在這一版中,前端人員把網(wǎng)頁(yè)的標(biāo)題設(shè)置放在了異步操作里,導(dǎo)致UIWebView在加載網(wǎng)頁(yè)完成后,在代理方法webViewDidFinishLoad:里無(wú)法立即獲取標(biāo)題,因?yàn)楂@取標(biāo)題的方法是異步的,而網(wǎng)頁(yè)加載完就會(huì)調(diào)用該代理方法,那時(shí)候的網(wǎng)頁(yè)title還沒(méi)有值,所以獲取不到title的值。

下面是網(wǎng)頁(yè)異步獲取title的代碼,使用了jQueryAjax技術(shù)來(lái)異步獲取title:

 $.ajax({
    url: remoteur+'/api/innerMessageApi/noticeMessage.htm?callBackFunc=xx',
    type: 'get',
    dataType: 'jsonp',
    jsonpCallback:"xx",
    data: {msgId: msgId},

    success: function(res){
      console.log(res);
      if ( res.successFlag == 'Y' ){
        content = res.content;
        title  = res.title;
      }
    },
    complete:function(res){
      document.title = title;
      $('body').append(content);
    }
  })

出現(xiàn)這個(gè)問(wèn)題的時(shí)候,恰是項(xiàng)目要上線的那天晚上,在集體加班時(shí),遇到這個(gè)問(wèn)題,感覺那一夜,被深深傷害。。。

好了,閑話不多說(shuō),下面來(lái)介紹解決辦法:

方法一

如果只是考慮iOS方面的解決方法,可能就是延時(shí)獲取title,具體就是在webViewDidFinishLoad:里通過(guò)延時(shí)來(lái)執(zhí)行document.title來(lái)獲取標(biāo)題,雖然可以解決,但是有風(fēng)險(xiǎn),因?yàn)榫W(wǎng)頁(yè)獲取標(biāo)題是異步的,而異步的時(shí)間就不確定,所以延時(shí)的時(shí)間也不確定,雖然可以加大延時(shí)的時(shí)間,但是不是完美的解決方法

  dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(3 * NSEC_PER_SEC)),    

  dispatch_get_main_queue(), ^{
    self.title = [webView stringByEvaluatingJavaScriptFromString:@"document.title"];
  });

方法二

如果考慮網(wǎng)頁(yè)端,可以把網(wǎng)頁(yè)中獲取title的異步操作改成同步操作,根據(jù)上述的js代碼,可以添加一個(gè)同步的字段async: false,修改后的網(wǎng)頁(yè)代碼如下:

$.ajax({
    url: remoteur+'/api/innerMessageApi/noticeMessage.htm?callBackFunc=xx',
    type: 'get',
    dataType: 'jsonp',
    jsonpCallback:"xx",
    data: {msgId: msgId},
    // 設(shè)置同步操作
    async: false,

    success: function(res){
      // 同步設(shè)置標(biāo)題
       document.title = res.title;
    complete:function(res){
      ...
    }
  })

雖然這樣可以解決該問(wèn)題,但是依然不是很好的解決辦法,比如網(wǎng)頁(yè)在加載時(shí),用同步的方式獲取網(wǎng)頁(yè)標(biāo)題,假如同步操作被阻塞,那么網(wǎng)頁(yè)加載就被阻塞,進(jìn)而導(dǎo)致網(wǎng)頁(yè)無(wú)法展示,所以依然不是最優(yōu)的解決方法。

方法三

如果把網(wǎng)頁(yè)端和iOS端結(jié)合起來(lái),可以在網(wǎng)頁(yè)端異步獲取標(biāo)題,在獲取到標(biāo)題后通過(guò)js調(diào)用原生的方法來(lái)設(shè)置標(biāo)題,這樣既可以不因同步獲取標(biāo)題而阻塞網(wǎng)頁(yè)加載過(guò)程,也不會(huì)因延時(shí)獲取標(biāo)題而造成延時(shí)時(shí)間無(wú)法確定的問(wèn)題,所以該方法可以完美解決這個(gè)問(wèn)題

js端代碼:

$.ajax({
    url: remoteur+'/api/innerMessageApi/noticeMessage.htm?callBackFunc=xx',
    type: 'get',
    dataType: 'jsonp',
    jsonpCallback:"xx",
    data: {msgId: msgId},
    // 設(shè)置同步操作
    async: false,

    success: function(res){
      // 同步設(shè)置標(biāo)題
      document.title = res.title;
      // js調(diào)用原生方法來(lái)設(shè)置標(biāo)題
      setWebViewTitle(title); 
    complete:function(res){
      ...
    }
  })

iOS端代碼:

  context[@"setWebViewTitle"] = ^(){
    NSArray *args = [JSContext currentArguments];
    if (args.count == 1) {
      // 設(shè)置標(biāo)題,只需要傳遞一個(gè)參數(shù)
      self.title = [args firstObject];
    }
  };

關(guān)于“iOS之UIWebView無(wú)法如何獲取web標(biāo)題”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

當(dāng)前標(biāo)題:iOS之UIWebView無(wú)法如何獲取web標(biāo)題
文章分享:http://www.chinadenli.net/article6/jiijog.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)靜態(tài)網(wǎng)站商城網(wǎng)站企業(yè)網(wǎng)站制作微信小程序搜索引擎優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

小程序開發(fā)