ios UITextView placeHolder效果

我们知道UITextView没有像UITextField一样的placeholder属性。
但是我们通过如下方法让UITextView实现一样的效果

1.给UITextView添加初始化默认文字,当成placeholder,并且颜色设置成灰色
2.ViewController实现UITextView的代理UITextViewDelegate
class yourUIViewController:UIViewController,UITextViewDelegate{
    override func viewDidLoad() {
        super.viewDidLoad()
        textView.delegate = self
    }
}
3.复写textViewShouldBeginEditing函数,当用户开始编辑UITextView 时将UITextView的文字清除,同时将文字颜色变回黑色
func textViewShouldBeginEditing(_ textView: UITextView) -> Bool {
    if (self.hasUserInputSomething == false) {
        textView.text = ""
        textView.textColor = UIColor.black
    }
    return true
}

你可能注意到了代码里面的hasUserInputSomething
它是为了区别如下情况:
用户已对UITextView编辑过,再次编辑时,这个时候不能把之前用户已经输入的内容当成placeholder清除,所以我加了这个变量,判断只有当用户没有往UITextView中输入内容时才会清除UITextView中的文字,也就是placeholder

4.复写textViewShouldEndEditing函数,当用户退出UITextView的编辑时,需要判断是否对UITextView输入了内容,如果有输入,那么不做任何动作,如果最后输入的内容为空,则需要给UITextView重新添加placeholder文字,并将文字颜色变回为灰色
func textViewShouldEndEditing(_ textView: UITextView) -> Bool {
    //收起输入法时进行判断
    if textView.text == "" {
        textView.text = "请输入..."
        textView.textColor = UIColor(red: 181/255, green: 181/255, blue: 181/255, alpha: 1)
        self.hasUserInputSomeThing = false
    }else{
        self.hasUserInputSomeThing = true
    }
    return true
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值