美文网首页初见
iOS关于限制输入注意点

iOS关于限制输入注意点

作者: 似云淡若风轻 | 来源:发表于2019-03-04 17:25 被阅读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);

        }

    }

    相关文章

      网友评论

        本文标题:iOS关于限制输入注意点

        本文链接:https://www.haomeiwen.com/subject/ridiuqtx.html