实现placeholder属性的UITextView

转载 2016年05月31日 10:02:39

本文出处刚刚在线:http://www.superqq.com/blog/2015/08/07/implement-uitextview-placeholder/

iOS开发微信公众号上的iOS技术文章,都将发布在刚刚在线。所以大家可以到我的网站上查看之前的文章,也可以在底部的精彩文章查看历史文章。

上一篇文章UITextView实现placeholder的猥琐做法讲了关于UITextView的placeholder实现原理。大家都一致认为做法比较猥琐。

那么,这一次我将简单的封装一个UITextView。暂且取名叫GGPlaceholderTextView,GG前缀看着有点任性的哈。

GGPlaceholderTextView简介

GGPlaceholderTextView也是对text操作,具体逻辑如下:

继承UITextView,并设置placeholder属性
注册开始编辑和结束编辑通知,然后对text做相应的操作
通过UIApplicationWillTerminateNotification通知,在APP退出的时候移除通知。
我把GGPlaceholderTextView写在下面。不过,微信里看代码还是不太方便,我已经把代码push到:iOSStrongDemo。你可以下载下来。

GGPlaceholderTextView.h

#import <UIKit/UIKit.h>

@interface GGPlaceholderTextView : UITextView
@property(nonatomic, strong) NSString *placeholder;

@end

定义placeholder属性,类似于UITextField。

GGPlaceholderTextView.m

#import "GGPlaceholderTextView.h"

@implementation GGPlaceholderTextView

- (id)initWithFrame:(CGRect)frame {
    if (self = [super initWithFrame:frame]) {
        [self addObserver];
    }
    return self;
}

- (id)init {
    if (self = [super init]) {
        [self addObserver];
    }
    return self;
}

- (void)setPlaceholder:(NSString *)placeholder
{
    _placeholder = placeholder;
    self.text = placeholder;
    self.textColor = [UIColor grayColor];
}

-(void)addObserver
{
    //注册通知
    [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(didBeginEditing:) name:UITextViewTextDidBeginEditingNotification object:self];
    [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(didEndEditing:) name:UITextViewTextDidEndEditingNotification object:self];
    [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(terminate:) name:UIApplicationWillTerminateNotification object:[UIApplication sharedApplication]];
}

- (void)terminate:(NSNotification *)notification {
    //移除通知
    [[NSNotificationCenter defaultCenter] removeObserver:self];
}

- (void)didBeginEditing:(NSNotification *)notification {
    if ([self.text isEqualToString:self.placeholder]) {
        self.text = @"";
        self.textColor = [UIColor blackColor];
    }
}

- (void)didEndEditing:(NSNotification *)notification {
    if (self.text.length<1) {
        self.text = self.placeholder;
        self.textColor = [UIColor grayColor];
    }
}

@end

以上就是关于GGPlaceholderTextView的实现,如果你有类似需求,直接拿去用吧!具体用法请往下看。

实践

GGPlaceholderTextView *textView = [[GGPlaceholderTextView alloc] initWithFrame:CGRectMake(0, 64, SCREEN.width , 200)];
textView.backgroundColor = [UIColor whiteColor];
textView.placeholder = @"关注微信公众号iOS开发:iOSDevTip";
[self.view addSubview:textView];

经过封装后的GGPlaceholderTextView,使用起来是不是跟UITextField非常相似。当然,我封装的比较简单,github上也有一些朋友封装带placeholder属性的UITextView。比如:TextViewPlaceholder。感兴趣的童鞋可以去试用一下。

(想用block kit)不用通知 。

实现placeholder属性的UITextView

GGPlaceholderTextView简介 GGPlaceholderTextView也是对text操作,具体逻辑如下: 继承UITextView,并设置placeholder属性...

UITextView 实现placeholder的方法

在UITextField中自带placeholder属性,可以用于提示输入框信息。但是UITextView并不具备此功能 介绍两种方法来实现: 第一种: 初始化UITextView /...
  • mdk132
  • mdk132
  • 2013年12月31日 18:49
  • 832

史上最全的iOS之UITextView实现placeHolder占位文字的N种方法

前言 iOS开发中,UITextField和UITextView是最常用的文本接受类和文本展示类的控件。UITextField和UITextView都输入文本,也都可以监听文本的改变。不同的是,UI...

iOS开发:UITextView实现placeHolder占位文字的N种方法

前言 iOS开发中,UITextField和UITextView是最常用的文本接受类和文本展示类的控件。UITextField和UITextView都输入文本,也都可以监听文本的改变。不同的是,UI...

UITextView实现placeholder的猥琐做法

我们都知道iOS开发中的`UITextField`有个`placeholder`属性,`placeholder`可以很方便引导用户输入。但是`UITextView`却没有`placeholder`属性...
  • conslee
  • conslee
  • 2015年08月07日 09:48
  • 730

UITextView增加PlaceHolder

  • 2016年04月18日 15:46
  • 58KB
  • 下载

UITextView+placeholder

  • 2016年03月25日 15:18
  • 2KB
  • 下载

UITextView和UITextField的placeholder,键盘隐藏,键盘换行变完成字样

- (void)initFeedBackViews {     //设置页面的背景颜色     UIColor *ViewBgColor = [UIColor colorWithRed:...

UITextView添加placeholder属性

一行代码解决UITextview添加placeholder属性

UITextView 的placeholder

UITextField是没有分行功能,如果先要输入多行文字,就需要用到UITextView,但是在使用UITextView的时候,我们也想给用户一个提示语,这个怎么实现呢??说起UITextfield...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:实现placeholder属性的UITextView
举报原因:
原因补充:

(最多只允许输入30个字)