首先说下textview的placeholder实现,大家都知道textfield是直接有placeholder效果的,就在网上找了下实现方式。

实现代码如下:

[Swift] 纯文本查看 复制代码
    var defaultTextColor = UIColor(white: 0, alpha: 0.3)
    var defaultText = "Enter optional text here..."
    var contentColor = UIColor.blackColor()
    func textViewDidBeginEditing(textView: UITextView) {
        if textView.textColor == defaultTextColor
        {
            textView.text = ""
            textView.textColor = contentColor
        }
    }
    
    func textViewDidEndEditing(textView: UITextView) {
        if textView.text == ""
        {
            textView.textColor = defaultTextColor
            textView.text = defaultText
        }
    }


很简单,就是开始编辑的时候,如果颜色为占位符的颜色,就把占位符取消换成内容的颜色。结束编辑的时候,如果内容为空,就显示占位符。

后来发现这种实现的效果和textfield中的效果不一致,textfield中输入内容时占位符消失,上述效果是光标进入时占位符消失。

我在stack over flow 上看见一种解决办法,挺好的。

代码如下:

[Swift] 纯文本查看 复制代码
    override func viewDidLoad() {
        textView.delegate = self
        placeholderLabel = UILabel()
        placeholderLabel.text = "Enter optional text here..."
        placeholderLabel.font = UIFont.italicSystemFontOfSize(textView.font!.pointSize)
        placeholderLabel.sizeToFit()
        textView.addSubview(placeholderLabel)
        placeholderLabel.frame.origin = CGPointMake(5, textView.font!.pointSize / 2)
        placeholderLabel.textColor = UIColor(white: 0, alpha: 0.3)
        placeholderLabel.hidden = !textView.text.isEmpty
    }
    func textViewDidChange(textView: UITextView) {
        placeholderLabel.hidden = !textView.text.isEmpty
    }


实现逻辑是在textview上放一个label当做占位符,编辑的时候控制label的显示和隐藏。

如果哪位朋友有更好的解决方案,请给我回复。

textview实现placeholder效果

textview实现placeholder效果 - 敏捷大拇指 - textview实现placeholder效果