突出显示文本字段内的文本

发布于 2024-10-17 05:40:43 字数 128 浏览 12 评论 0原文

我希望当我点击文本字段内的文本时突出显示它。

我希望有人点击数字键盘时删除原始文本。我尝试使用clearButtonMode,但由于我的文本字段大小非常小,十字图标完全占据了文本字段。

知道如何实现这一目标吗?

I want the text inside the textfield to be highlighted when I tap on it.

I want the original text to be deleted the moment someone tap on the numberpad. I tried using clearButtonMode but then since my textfield size is very small the cross icon fully occupy the textfield.

Any idea how to achieve this?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(5

云裳 2024-10-24 05:40:43

这可以通过以下方式实现

(void)textFieldDidBeginEditing:(UITextField *)iTextField {
    [iTextField selectAll:self];
}

This can be achieved by

(void)textFieldDidBeginEditing:(UITextField *)iTextField {
    [iTextField selectAll:self];
}
岁月苍老的讽刺 2024-10-24 05:40:43

你需要自己做亮点。您可以尝试:

  • 更改文本字段的字体(更大、更粗、不同颜色),
  • 在文本字段顶部覆盖透明的 UIView。
  • 更改文本字段的背景
  • 更改边框样式

有很多选项...

编辑:为了回答您的问题,为了在文本字段中开始编辑时清除先前值的字段,您将对象设置为遵循UITextFieldDelegate协议,实现该方法:

- (void)textFieldDidBeginEditing:(UITextField *)textField
{
    textField.text = nil;
}

You need to do the highlight yourself. You could try:

  • changing the font of the text field (larger, bolder, different color)
  • overlaying a transparent UIView on top of the text field.
  • changing the background of the text field
  • change the border style

there are many options...

EDIT: in response to your question, in order to clear the field of the previous value whenever editing begins in your text field, you set up your object to conform to the UITextFieldDelegate protocol, and implement this method:

- (void)textFieldDidBeginEditing:(UITextField *)textField
{
    textField.text = nil;
}
猫弦 2024-10-24 05:40:43

在点击文本字段时突出显示文本的最简单方法就是将 UITextField 子类化,覆盖BecomeFirstResponder 并选择其中的所有文本。

The easiest way to highlight the text on tapping of the text field is simply to subclass UITextField, override becomeFirstResponder and select all text in there.

℡Ms空城旧梦 2024-10-24 05:40:43

如果全选:并不总是有效,这里有一个修复方法:

- (void)textFieldDidBeginEditing:(UITextField *)textField
{
    [textField performSelector:@selector(selectAll:) withObject:textField afterDelay:0.f];
}

If Select All: doesn't always work here's a fix:

- (void)textFieldDidBeginEditing:(UITextField *)textField
{
    [textField performSelector:@selector(selectAll:) withObject:textField afterDelay:0.f];
}
梦幻的心爱 2024-10-24 05:40:43

如果您仍然希望能够在 ViewController 中使用其他委托函数,我建议您添加以下内容:

override weak var delegate: UITextFieldDelegate? {
    didSet {
        if delegate?.isKindOfClass(YourTextField) == false {
            // Checks so YourTextField (self) doesn't set the textFieldDelegate when assigning self.delegate = self 
            textFieldDelegate = delegate
            delegate = self
        }
    }
}

// This delegate will actually be your public delegate to the view controller which will be called in your overwritten functions
private weak var textFieldDelegate: UITextFieldDelegate?

class YourTextField: UITextField, UITextFieldDelegate {

    init(){
        super.init(frame: CGRectZero)
        self.delegate = self
    }

    func textFieldDidBeginEditing(textField: UITextField) {
        textField.performSelector(Selector("selectAll:"), withObject: textField)
        textFieldDelegate?.textFieldDidBeginEditing?(textField)
    }
}

这样您的视图控制器不需要知道您已经覆盖了委托,并且您可以在视图控制器中实现 UITextFieldDelegate 函数。

let yourTextField = YourTextField()
yourTextField.delegate = self

If you still want to be able to use other delegate functions in you ViewController, I recommend you to add this:

override weak var delegate: UITextFieldDelegate? {
    didSet {
        if delegate?.isKindOfClass(YourTextField) == false {
            // Checks so YourTextField (self) doesn't set the textFieldDelegate when assigning self.delegate = self 
            textFieldDelegate = delegate
            delegate = self
        }
    }
}

// This delegate will actually be your public delegate to the view controller which will be called in your overwritten functions
private weak var textFieldDelegate: UITextFieldDelegate?

class YourTextField: UITextField, UITextFieldDelegate {

    init(){
        super.init(frame: CGRectZero)
        self.delegate = self
    }

    func textFieldDidBeginEditing(textField: UITextField) {
        textField.performSelector(Selector("selectAll:"), withObject: textField)
        textFieldDelegate?.textFieldDidBeginEditing?(textField)
    }
}

This way your view controller doesn't need to know that you have overwritted the delegate and you can implement UITextFieldDelegate functions in your view controller.

let yourTextField = YourTextField()
yourTextField.delegate = self
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文