用UITextView模拟UITextField的placeHolder

用UITextView模拟UITextField的placeHolder

效果:

源码:

//
//  ViewController.m
//  TextView
//
//  Created by YouXianMing on 14/12/18.
//  Copyright (c) 2014年 YouXianMing. All rights reserved.
//

#import "ViewController.h"

static NSString *placeHolderStr = @"User Name";

@interface ViewController ()<UITextViewDelegate>

@property (nonatomic, strong) UITextView  *textView;
@property (nonatomic, strong) UIButton    *button;

@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    
    // 反应的按钮
    self.button = [[UIButton alloc] initWithFrame:self.view.bounds];
    [self.button addTarget:self
                    action:@selector(buttonEvent)
          forControlEvents:UIControlEventTouchUpInside];
    [self.view addSubview:self.button];
    
    // textView
    self.textView = [[UITextView alloc] initWithFrame:CGRectMake(0, 20, 320, 200)];
    self.textView.layer.borderWidth = 1.f;
    self.textView.layer.borderColor = [UIColor grayColor].CGColor;
    self.textView.delegate  = self;
    self.textView.text      = placeHolderStr;
    self.textView.font      = [UIFont systemFontOfSize:20.f];
    self.textView.textColor = [UIColor grayColor];
    [self.view addSubview:self.textView];
}

#pragma mark - 代理方法
- (BOOL)textViewShouldBeginEditing:(UITextView *)textView {
    // 设置编辑状态文字颜色
    textView.textColor = [UIColor blackColor];
    
    // 如果文字为placeHolder文字
    if ([textView.text isEqualToString:placeHolderStr]) {
        textView.text      = @"";
    }
    
    return YES;
}
- (BOOL)textViewShouldEndEditing:(UITextView *)textView {
    
    // 如果长度为0,则显示placeHolder文字
    if (textView.text.length == 0) {
        textView.text = placeHolderStr;
        textView.textColor = [UIColor grayColor];
    }
    
    return YES;
}

/**
 *  反应的按钮
 */
- (void)buttonEvent {
    [self.textView resignFirstResponder];
}

@end

核心代码:

 

  • 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、付费专栏及课程。

余额充值