ios UITextView 添加水印提示(Placeholder)

实现UITextView和UITextField相同效果的水印提示,可根据自己要求更改

1、定义textview的时候设置其属性:

    textView.textColor=[UIColor lightGrayColor];//设置提示内容颜色
    textView.text=NSLocalizedString(@"InputReason", nil);//提示语
    textView.selectedRange=NSMakeRange(0,0) ;//光标起始位置
    textView.delegate=self;代理

2、- (void)textViewDidChangeSelection:(UITextView *)textView
{
     if (textView.textColor==[UIColor lightGrayColor]

&&[textView.text isEqualToString:NSLocalizedString(@"InputReason", nil)]

)//如果是提示内容,光标放置开始位置
     {
    NSRange range;
    range.location = 0;
    range.length = 0;
    textView.selectedRange = range;
     } else if (textView. textColor ==[ UIColor lightGrayColor ])//中文输入键盘

    {

        NSString *placeholder=NSLocalizedString(@"InputReason", nil);

        textView.textColor=[UIColor blackColor];

        textView.text=[textView.text substringWithRange:NSMakeRange(0, textView.text.length- placeholder.length)];

    }



}

-(BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString*)text
{
    if (![text isEqualToString:@""]&&textView.textColor==[UIColor lightGrayColor])//如果不是delete响应,当前是提示信息,修改其属性
    {
        textView.text=@"";//置空
        textView.textColor=[UIColor blackColor];
    }
    
    if ([text isEqualToString:@"\n"])//回车事件
    {
        if ([textView.text isEqualToString:@""])//如果直接回车,显示提示内容
        {
            textView.textColor=[UIColor lightGrayColor];
            textView.text=NSLocalizedString(@"InputReason", nil);
        }
        [textView resignFirstResponder];//隐藏键盘
        return NO;
    }
    return YES;
}
- (void)textViewDidChange:(UITextView *)textView
{
    if ([textView.text isEqualToString:@""])
    {
        textView.textColor=[UIColor lightGrayColor];
        textView.text=NSLocalizedString(@"InputReason", nil);
    }
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值