初见

iOS关于限制输入注意点

2019-03-04  本文已影响0人  似云淡若风轻

1.在限制输入个数时, 如果此时通过copy操作插入到最后一行,让后摇晃手机弹出系统的撤销框, 在点击撤销时有可能崩溃。

    原因:系统在撤销输入时,会在对应的range做操作,但是由于限制了输入个数, 且该range操作了原输入的字符个数,导致在操作是越界。所以需要增加判断

      BOOLisDeleting = range.length>0&& string.length<=0;

        if(isDeleting) {

            if(NSMaxRange(range) > textField.text.length) {

                // 借阅于https://github.com/Tencent/QMUI_iOS/issues/377

                returnNO;

            }else{

                returnYES;

            }

        }

2.UITextField 输入中文超过文本框宽度后再删除,文字会往下掉

原因:UITextField.frame 的高度要比 UITextField.font.lineHeight 或者 UITextField.defaultTextAttributes[NSParagraphStyleAttributeName].minimumLineHeight 的整数值(ceil 运算)大。输入的文字要超过文本框的宽度,也即出现横向滚动。在此情况下一个一个字地删除,文字就会往下掉。或者不用删除文字,而是在文本框里往右上角拖拽,就会看到文字往左下方掉。与 contentVerticalAlignment 的值无关。

- (void)scrollViewDidScroll:(UIScrollView*)scrollView {

// 借阅于https://github.com/Tencent/QMUI_iOS/issues/64

    if(scrollView !=self.textField.subviews.firstObject) {

        return;

    }

    CGFloat lineHeight = ((NSParagraphStyle *)self.textField.defaultTextAttributes[NSParagraphStyleAttributeName]).minimumLineHeight;

    lineHeight = lineHeight ?: ((UIFont *)self.textField.defaultTextAttributes[NSFontAttributeName]).lineHeight;

    if(scrollView.contentSize.height>ceil(lineHeight) && scrollView.contentOffset.y<0) {

        scrollView.contentOffset=CGPointMake(scrollView.contentOffset.x,0);

    }

}

上一篇下一篇

猜你喜欢

热点阅读