溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

淺談iOS解析HTMl標(biāo)簽以及開(kāi)發(fā)中的一些坑

發(fā)布時(shí)間:2020-09-16 10:04:08 來(lái)源:腳本之家 閱讀:137 作者:夜3033 欄目:移動(dòng)開(kāi)發(fā)

開(kāi)篇

看了看更新日期好久沒(méi)寫簡(jiǎn)書了,經(jīng)常還有小伙伴在文章下面評(píng)論,看到自己寫的東西還是有點(diǎn)用的,鼓勵(lì)自己接著堅(jiān)持下去吧,哈哈。今天主要就寫寫iOS中怎么解析HTML標(biāo)簽,我們常用的后臺(tái)返回?cái)?shù)據(jù)一般是json格式的但是有些時(shí)候如果我們收到的是帶HTMl標(biāo)簽的我們?cè)撛趺刺幚硭?,今天就?lái)說(shuō)一說(shuō)吧。

正文

前兩天獲取后臺(tái)數(shù)據(jù)的時(shí)候,得到這么一條返回信息

"恭喜您獲得<font color='red'>8.1元</font>現(xiàn)金獎(jiǎng)勵(lì) "

本來(lái)簡(jiǎn)簡(jiǎn)單單的把返回?cái)?shù)據(jù)展示到label上的事情一下子變得有趣起來(lái),后臺(tái)說(shuō)是為了以后產(chǎn)品改返回內(nèi)容的時(shí)候容易處理,可以這理由很強(qiáng)勢(shì)。

淺談iOS解析HTMl標(biāo)簽以及開(kāi)發(fā)中的一些坑

但是作為開(kāi)發(fā)的我們?cè)趺刺幚砟?,首先我們看下安卓的處理方法,安卓?duì)處理這個(gè)還是比較粗暴的人家有系統(tǒng)方法,如下:

淺談iOS解析HTMl標(biāo)簽以及開(kāi)發(fā)中的一些坑

那么iOS端怎么處理呢,我們可以用webview,也可以用Label的attributedString屬性,也可以直接簡(jiǎn)單粗暴的分割字符串,然后去除HTML標(biāo)簽,然后處理,聽(tīng)聽(tīng)就讓人惆悵,然而畢竟是一種方法,能解決問(wèn)題的方法都是好方法,我們就放一下最粗暴方法的主要代碼(其余方法在評(píng)論補(bǔ)充有,哈哈),去除HTML標(biāo)簽的方法如下:

//過(guò)濾后臺(tái)返回字符串中的標(biāo)簽
- (NSString *)flattenHTML:(NSString *)html {
  
  NSScanner *theScanner;
  NSString *text = nil;
  
  theScanner = [NSScanner scannerWithString:html];
  
  while ([theScanner isAtEnd] == NO) {
    // find start of tag
    [theScanner scanUpToString:@"<" intoString:NULL] ;
    // find end of tag
    [theScanner scanUpToString:@">" intoString:&text] ;
    // replace the found tag with a space
    //(you can filter multi-spaces out later if you wish)
    html = [html stringByReplacingOccurrencesOfString:
        [NSString stringWithFormat:@"%@>", text]
                        withString:@""];
  }
  MidStrTitle = html;
  return html;
}

這樣我們就處理掉了HTML標(biāo)簽,那么問(wèn)題來(lái)了,如果我們要處理的是很多的HTML標(biāo)簽?zāi)?,我們?cè)撛趺刺幚砟?,這就是這篇文章的目的。

TFHpple庫(kù)

如果我們想要得到是如下一個(gè)HTML源碼中某一個(gè)標(biāo)簽的內(nèi)容呢,部分源碼如下,這里只是放了標(biāo)簽部分的內(nèi)容

<title>關(guān)于APP的聲明</title>

</head>
<body>
<h4>關(guān)于APP的聲明</h4>

<p>只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試</p>

<p>只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試</p>

<h4>聯(lián)系我們</h4>

<p>若您在使用該APP有遇到任何問(wèn)題或有新想法,都可以聯(lián)系我們. 如下是我們的聯(lián)系方式:</p>

<ul>
<li>只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試</li>
<li>E-mail: xxxxxxxxxxxxxxxxxxxxxxxxxx</li>
<li>phone: xxxxxxxxxxxxxxxxxx</li>
</ul>


<h4>感謝</h4>

<p>首先,感謝廣大用戶對(duì)公司的支持和鼓勵(lì),謝謝你們對(duì)我們的一路支持.</p>

<p>只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試</p>

<h4>版權(quán)聲明</h4>

<p>只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試只是測(cè)試</p>
</body>
</html>

這里如果我要針對(duì)性取某一個(gè)標(biāo)簽的內(nèi)容就要用到我們今天介紹的庫(kù)了。

環(huán)境的配置

導(dǎo)入靜態(tài)庫(kù)

淺談iOS解析HTMl標(biāo)簽以及開(kāi)發(fā)中的一些坑

然后把導(dǎo)入的靜態(tài)庫(kù)添加到文件的路徑

淺談iOS解析HTMl標(biāo)簽以及開(kāi)發(fā)中的一些坑

然后導(dǎo)入TFHpple庫(kù)就可以了。

使用方法1,簡(jiǎn)單的標(biāo)簽形式取值法

直接上代碼

NSString *resourcePath = [[NSBundle mainBundle] resourcePath];
    NSString *filePath =[resourcePath stringByAppendingPathComponent:@"about.html"];
    NSData *data =[[NSData alloc]initWithContentsOfFile:filePath];
    NSString *result = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];  //data轉(zhuǎn)字符串 為了打印不是亂碼
    NSLog(@"------%@",result);
  
    TFHpple *Hpple = [[TFHpple alloc]initWithHTMLData:data];
  
    //測(cè)試1:獲取簡(jiǎn)單的標(biāo)題
    NSArray *array =[Hpple searchWithXPathQuery:@"http://title"]; //獲取到為title的標(biāo)題
  
    for (TFHppleElement *HppleElement in array) {
  
      NSLog(@"測(cè)試1的目的標(biāo)簽內(nèi)容:-- %@",HppleElement.text);
      
    }

我們首先獲取到本地的about.html的文件,然后轉(zhuǎn)化為data,加UTF8編碼轉(zhuǎn)換為我們可以看到的容如下圖:

淺談iOS解析HTMl標(biāo)簽以及開(kāi)發(fā)中的一些坑

上部分為HTML文件的原標(biāo)簽,下部分為我們?nèi)サ降臉?biāo)簽為“title”的內(nèi)容。 這樣我們就得到了我們想要的

使用方法2:有自己屬性的標(biāo)簽內(nèi)容取值

上面的那個(gè)HTML文件由于內(nèi)容的局限性不方便我們舉例,我們使用的HTML標(biāo)簽源碼如下:

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>hello</title>
</head>
<body>hello world
<span>
</span>
無(wú)序列表
<ul type="disc">
  <li>蘋果</li>
  <li>水果</li>
  <li>桃子</li>
</ul>
<ul type="circle">
  <li>蘋果2</li>
  <li>水果2</li>
  <li>桃子2</li>
</ul>
</body>
</html>

我們想去取到的是無(wú)序列表 節(jié)點(diǎn)屬性為type 屬性值為disc的標(biāo)簽內(nèi)容,顯然上面的方法已經(jīng)不能滿足我們的需要,老規(guī)矩先上代碼:

//測(cè)試2:獲取更加詳細(xì)的內(nèi)容
  NSString *resourcePath = [[NSBundle mainBundle] resourcePath];
  NSString *filePath =[resourcePath stringByAppendingPathComponent:@"first.html"];
  NSData *data =[[NSData alloc]initWithContentsOfFile:filePath];
  
  NSString *result = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];  //data轉(zhuǎn)字符串 為了打印不是亂碼
  NSLog(@"------%@",result);
  
  TFHpple *Hpple = [[TFHpple alloc]initWithHTMLData:data];
  NSArray *array =[Hpple searchWithXPathQuery:@"http://ul"];
  
  for (TFHppleElement *HppleElement in array) {
    
    if ([HppleElement.attributes[@"type"]isEqualToString:@"disc"]) { //找出 ul標(biāo)簽下 節(jié)點(diǎn)屬性type  屬性值為 disc 的數(shù)組
      
      NSArray *array2 = [HppleElement searchWithXPathQuery:@"http://li"];
      
      for (TFHppleElement *HppleElement2 in array2) {
        
        NSLog(@"測(cè)試2的目的標(biāo)簽內(nèi)容:-- %@",HppleElement2.text);
      }
    }
  }

使用方法重點(diǎn)在下面的這個(gè)if語(yǔ)句的判斷里

 if ([HppleElement.attributes[@"type"]isEqualToString:@"disc"]) {
}

如果存在這種條件下的內(nèi)容,根據(jù)這個(gè)BOOL值,去取到下面標(biāo)簽為“l(fā)i‘的內(nèi)容 運(yùn)行結(jié)果如下:

淺談iOS解析HTMl標(biāo)簽以及開(kāi)發(fā)中的一些坑

項(xiàng)目中遇到的一些坑

我們?nèi)⊥炅藰?biāo)簽并不能結(jié)束,好不容易有時(shí)間就再寫一下一些遇到的小的問(wèn)題吧。

自定義鍵盤

自定義鍵盤也算是老問(wèn)題了,由于情況的不同,我們可能需要定義一個(gè)完全自定義的鍵盤,來(lái)適應(yīng)各種奇葩的需求。最近看代碼的時(shí)候才發(fā)現(xiàn)不同的人寫法真不一樣,這里介紹一個(gè)個(gè)人認(rèn)為比較簡(jiǎn)單的方法吧。

UITextField的inputView的屬性,用法舉例如下:

kkeyboardView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 320 ,260 )] ;
  kkeyboardView.backgroundColor = [UIColor lightGrayColor];
  [self setUpMyKeyBoard2];
  self.textfiled.inputView = kkeyboardView;

創(chuàng)建一個(gè)View 然后把它作為UITextField的inputView,這個(gè)時(shí)候就可以完全的自定義自己想要的自定義鍵盤了,產(chǎn)品你過(guò)來(lái)說(shuō)說(shuō)你還要鍵盤上有啥。

淺談iOS解析HTMl標(biāo)簽以及開(kāi)發(fā)中的一些坑

UIScrollView的滾動(dòng)問(wèn)題

前天同事說(shuō)了一個(gè)奇怪的問(wèn)題,說(shuō)懶加載也寫了,布局也搞了,偏移量也設(shè)置了,在別的頁(yè)面都搞好了,這個(gè)頁(yè)面的滾動(dòng)試圖忽然就不動(dòng)了。老司機(jī)也翻車了喜聞樂(lè)見(jiàn),但是問(wèn)題怎么處理呢。

-(void)viewDidLayoutSubviews
{
  _BaseScore.contentSize = CGSizeMake(SCREEN_WIDTH, 568.0 - 44); 
}

一陣折騰之后給了他這個(gè)方法,把偏移量寫在這個(gè)方法里就可以滾動(dòng)了,同事不禁說(shuō)老了老了,發(fā)現(xiàn)自己記憶越來(lái)越差了,哈哈,有一群這樣的同事真的工作比較開(kāi)心。

后記

今天的主要介紹就這么多吧,希望對(duì)需要的小伙伴有所幫助,有時(shí)間的話下次寫一下,項(xiàng)目中用到的,商家端生成二維碼收款,用戶端掃描二維碼付款,以及定時(shí)刷新,狀態(tài)判斷,掃描二維碼生成邀請(qǐng)碼等一系列二維碼相關(guān)的功能。有寫的不對(duì)地方的歡迎指出,大神輕噴,哈哈。

補(bǔ)充: 再補(bǔ)充兩條簡(jiǎn)單情況下的方法:

Label的attributedString屬性

NSAttributedString * attrStr = [[NSAttributedString alloc] initWithData:[h6str dataUsingEncoding:NSUnicodeStringEncoding] options:@{ NSDocumentTypeDocumentAttribute: NSHTMLTextDocumentType } documentAttributes:nil error:nil];
[selflab setAttributedText:attrStr];

利用web view

_webView = [[UIWebView alloc] initWithFrame:CGRectMake(100, 100, 100, 100)];
NSString *html_str = [NSString stringWithFormat:@"<div style='color:red'>666666</div> 測(cè)試 %@",@"新風(fēng)作浪",@"2020-01-00"];
[self.webView loadHTMLString:html_str baseURL:nil];
[self.view addSubview:self.webView];

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI