iOS-UITextView占位文字placeholder

自定义类,继承UITextView,实现类似于UITextField的占位文字效果,用户输入文本后占位文字消失.

使用方法仅需两行代码:

XWPlaceholderTextView *placholderTextView = [XWPlaceholderTextView shareWithFrame:CGRectMake(0, 0, kScreenWidth, kScreenHeight - 64) withPlaceholder:@"我们将根据您反馈的意见和问题, 提升产品的体验感!您的声音很重要"];
    [self.view addSubview:placholderTextView];

.h

//
//  XWPlaceholderTextView.h
//  Spread
//
//  Created by 邱学伟 on 16/4/18.
//  Copyright © 2016年 邱学伟. All rights reserved.
//  有占位文字的UITextView

#import <UIKit/UIKit.h>

@interface XWPlaceholderTextView : UITextView

/**
 *  占位文字
 * 我们将根据您反馈的意见和问题, 提升产品的体验感!
 */
@property (nonatomic, copy) NSString *placeholderStr;
/**
 *  工厂方法
 *
 *  @param frame          textView的尺寸
 *  @param placeholderStr 占位文字
 */
+(instancetype)shareWithFrame:(CGRect)frame withPlaceholder:(NSString *)placeholderStr;

/**
 *  初始化
 */
-(instancetype)initWithPlaceholder:(NSString *)placeholderStr;
@end

.m

//
//  XWPlaceholderTextView.m
//  Spread
//
//  Created by 邱学伟 on 16/4/18.
//  Copyright © 2016年 邱学伟. All rights reserved.
//

#import "XWPlaceholderTextView.h"

//间隔
#define kMargin 7
//字体大小
#define kFontSize 17

@interface XWPlaceholderTextView ()<UITextViewDelegate>

/**
 *  占位文本框
 */
@property (nonatomic, strong) UILabel *placeholderLB;

@end

@implementation XWPlaceholderTextView
#pragma mark - 懒加载
-(UILabel *)placeholderLB{
    if (_placeholderLB == nil) {
        _placeholderLB = [[UILabel alloc] init];
        _placeholderLB.textColor = [UIColor lightGrayColor];
        [_placeholderLB setNumberOfLines:0];
    }
    return _placeholderLB;
}
//初始化方法
-(instancetype)initWithFrame:(CGRect)frame withPlaceholder:(NSString *)placeholderStr{
    self = [super initWithFrame:frame];
    if (self) {
        //设置占位文本才会调用getter/setter方法
        self.placeholderStr = placeholderStr;
        self.delegate = self;
//        self.layer.cornerRadius = kMargin;
        self.font = [UIFont systemFontOfSize:kFontSize];
    }
    return self;
}
+(instancetype)shareWithFrame:(CGRect)frame withPlaceholder:(NSString *)placeholderStr{
    XWPlaceholderTextView *XWText = [[XWPlaceholderTextView alloc] initWithFrame:frame withPlaceholder:placeholderStr];
    return XWText;
}

#pragma mark - UITextViewDelegate
- (void)textViewDidChange:(UITextView *)textView {
    self.placeholderLB.hidden = textView.text.length;
}

#pragma mark - setter方法
-(void)setPlaceholderStr:(NSString *)placeholderStr{
    if (_placeholderStr != placeholderStr) {
        _placeholderStr = placeholderStr;
        //只有在设置占位文字时,才加载占位label
        [self addSubview:self.placeholderLB];
        //设置占位文本
        [self.placeholderLB setText:_placeholderStr];

        //占位文本Lable的尺寸
        NSDictionary *attributes = @{
                                     NSFontAttributeName:[UIFont systemFontOfSize:kFontSize]
                                     };
        //获取一段文本在规定长宽的尺寸
        CGRect placeholderLBSize = [_placeholderStr boundingRectWithSize:CGSizeMake(self.frame.size.width - kMargin * 2, 0) options:NSStringDrawingUsesLineFragmentOrigin |NSStringDrawingUsesFontLeading attributes:attributes context:nil];

        [self.placeholderLB setFrame:CGRectMake(kMargin, kMargin, placeholderLBSize.size.width, placeholderLBSize.size.height)];
    }
}


/*
// Only override drawRect: if you perform custom drawing.
// An empty implementation adversely affects performance during animation.
- (void)drawRect:(CGRect)rect {
    // Drawing code
}
*/

@end

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
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还支持更多的富文本样式设置,根据具体需求,可以设置更多的属性来实现更丰富的文本效果。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值