文档介绍::..ios知识点总结——富文本实现图文混排在iOS开发屮经常会遇到一些阁文混排的情况,特别是在微博类应用的开发过程屮经常会遇到各种表情,各种链接的解析。笔者在实践开发中经历了几次这种类型的幵发,由扱开始的利用WebView进行布局到最后利用富文本进行布局,对该部分的开发积累了一定的经验,现对富文本与正则表达式混用实现图文混排进行总结:,但是在使用的时候比较S杂,而且WebView的内存泄漏相当明品,使用不好反而得补偿失。现在很多的新闻类App都采用自己写的富文本进行图文混排。在很多情况下,富文本表现予外的是一个LabeI,将要显示的内容通过正则等封装成HTML字符串,然后显示在界面上,下面就是按照步骤实现这一功能:(1)先下载已经封装好的富文本标签类RCLabel(e/item/20694)该类是由一牛人封装好的用于实现图文混排的富文本类,在下载下来的源代码中可以看到其用法,但是这里有一个较为S杂的问题是你每次都需要手动将你要显示的A容封装成HTML格式的文本,这个过程相当繁琐而且容易出错,所以我在这个基础上进行了改进,将封装HTML的方法通过正则表达式独立开来,这样就实现了RCLabel与正则实现图文混排,以下是代码:将字符串转化成HTML的正则如下:.h文件#importion/>***@interfaceHtmIString:NSString+(NSString*)transformString:(NSString*)originalStr;***@:#import""#import/>#import""***@implementationHtmIString+(NSString*)transformString:(NSString*)originalStr{NSString*text=originalStr;//解析http://短链接NSString*regex_http=@"http⑻?://([a-zA-Z|\\d]+\\.)+[a-zA-Z|\\d]+(/[a-zA-Z|\\d|\\-n?";//http://短链接正则表达式NSArray*array_http=[ponentsMatchedByRegex:regex_http];if([array_httpcount]){for(NSString*strinarray_http){NSRangerange=[textrangeOfString:str];NSString*funUrlStr=[NSStringstringWithFormat:***@M<ahref,str,str];text=[textstring巳yRepIacingCharacterslnRange:NSMakeRange(,)withString:funUrlStr];}}"解析***@NSString*regex_at=***@n@[\\u4e00-\\u9fa5\\w\\-]+n;//(§^tiH则表达式NSArray*arr