UITextView使用

UITextView是一个很强大的多行文本控件,可滚动、可编辑、可添加自定义格式。在应用中可用来展示大文档,更可用来展示富文本(iOS6.0 and later)而不用使用UIWebView。

官方文档描述:

The UITextView class implements the behavior for a scrollable, multiline text region. The class supports the display of text using custom style information and also supports text editing. You typically use a text view to display multiple lines of text, such as when displaying the body of a large text document.

UITextView的真正强大之处在于它支持富文本功能,可以对文本中的任意文字、连续文字段、整行文字添加格式,这个功能在iOS6.0及以后的版本才能使用。该对象包含两个成员来分别保存需要显示的文本

     1. Stirng! / NSString * text
     2. NSAttributedString! /  NSAttributedString * attributedText

text存储无格式的字符串,attributedText存储有格式的文本,attributedText默认值为nil当给attributedText赋值时会自动将其无格式文本赋值给text。好接下来就来给TextView添加格式吧!

添加格式一共就只有三个步骤:
1. 获取UITextView.attributedString的可变拷贝
2. 向得到的MutableAttributedString添加格式
3. 将MutableAttributedStirng赋给UITextView.attributedString

改变文本的颜色:

效果图:

改变颜色

输出口:

@interface ViewController ()

@property (weak, nonatomic) IBOutlet UITextView *textView;

@end

颜色块按钮的点击事件代码:

- (IBAction)changeSelectedTextColorButtonClicked:(UIButton *)sender {

    //获取可变拷贝
    NSMutableAttributedString * attributedString = [self.textView.attributedText mutableCopy];
    //iOS7.0以后可以通过`self.textView.textStorage`获得可变属性字符串
    //添加格式属性
    [attributedString addAttribute:NSForegroundColorAttributeName
                             value:sender.backgroundColor
                             range:self.textView.selectedRange];
    //改变现有attrib
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
UITextView是UIKit框架中的一个控件,可以用来显示和编辑长文本。而富文本则是指带有丰富样式的文本,可以设置文字的字体、颜色、大小、间距、行高等属性。 要在UITextView中实现富文本,首先需要创建一个NSAttributedString对象,并通过NSMutableAttributedString来设置文字的样式。NSAttributedString是不可变的,而NSMutableAttributedString可以修改和添加样式。 创建NSMutableAttributedString对象后,可以使用其方法来设置文字的样式,比如设置字体可以使用NSFontAttributeName属性,设置颜色可以使用NSForegroundColorAttributeName属性,设置字号可以使用NSFontAttributeName属性,设置段落样式可以使用NSParagraphStyleAttributeName属性等等。 设置完成后,就可以将NSMutableAttributedString对象赋值给UITextView的attributedText属性,以实现富文本的显示。 例如,我们想将某个UITextView的文字样式设置为红色、字号为20、字体为粗体,可以按如下方式设置: ``` NSMutableAttributedString *attributedString = [[NSMutableAttributedString alloc] initWithString:@"这是富文本"]; [attributedString addAttribute:NSForegroundColorAttributeName value:[UIColor redColor] range:NSMakeRange(0, attributedString.length)]; [attributedString addAttribute:NSFontAttributeName value:[UIFont boldSystemFontOfSize:20] range:NSMakeRange(0, attributedString.length)]; textView.attributedText = attributedString; ``` 通过上述代码,就可以在UITextView中显示带有红色、字号为20、字体为粗体的文字。 除了以上示例外,UITextView还支持更多的富文本样式设置,根据具体需求,可以设置更多的属性来实现更丰富的文本效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值