• 最全的Swift社交应用文本输入优化汇总


    在大部分应用中,都有输入的需求,面对众多用户,他们的想法各异,输入的文本内容也是千奇百怪,面对不同的输入,我们该如何优化输入体验?本文将汇总一下Swift社交应用文本输入优化技巧。

    AD:

    一、输入相关的优化问题

    在大部分应用中,都有输入的需求,面对众多用户,他们的想法各异,输入的文本内容也是千奇百怪,面对不同的输入,我们该如何优化输入体验?本文将汇总一下Swift社交应用文本输入优化技巧。

    这里集中汇总输入相关问题,主要如下:

    输入控件UITextField跟随键盘移动

    过滤输入内容

    响应编程的处理,去除体验不好的对话框、HUD提示

    中文输入

    二、输入框随键盘移动

    界面构建有两种方法,代码或者storyboard/xib,这两种方法在处理键盘移动上方法相同,这里推荐使用已经封装好的第三方框架:TPKeyboardAvoiding
    1、代码处理方法

    rootView使用**TPKeyboardAvoding**框架中的TPKeyboardAvoidingScrollView来初使化。例如,登录界面,LoginViewController(继承自UIViewController),处理方法如下:

    1. let rootView = TPKeyboardAvoidingScrollView(frame: self.view.bounds); 
    2. //... 
    3. //add all subviews to rootView 
    4. //... 
    5. self.view.addSubview(rootView) 

    代码构建界面,实现输入框随键盘移动,需要将类**TPKeyboardAvoidingScrollView**做为根视图来处理。
    2、storyboard/xib处理办法

    storyboard/xib处理起来更简单,将视图控制器的rootView设置为TPKeyboardAvoidingScrollView即可

    (1)选择控制器的根视图

    (2)设置默认实例化类

     

    三、常用基本设置
    1、常用基本设置

    包括打开键盘、关闭键盘、指定键盘的输入类型、指定return按钮的类型,如以下代码

    1. //打开键盘 
    2. self.inputText.becomeFirstResponder() 
    3. //关闭键盘 
    4. self.inputText.resignFirstResponder() 
    5. //指定键盘的输入类型 
    6. self.inputText.keyboardType = UIKeyboardType.NumberPad 
    7. //指定return按键的类型 
    8. self.inputText.returnKeyType = UIReturnKeyType.Go 

    2、通过代理过滤输入

    通过UITextField/UITextView的代理,可以更精确的控制输入,例如:过滤指定字符、超过字符数禁止输入等

    (1)UITextField代码如下:

    1. //设置代理,可根据实际情况来设置代理,这里使用self来指定 
    2. self.textField.delegate = self 
    3.   
    4. //代理方法实现 
    5. func textField(textField: UITextField, shouldChangeCharactersInRange 
    6.  range: NSRange, replacementString string: String) -> Bool 
    7.     { 
    8.         //禁止输入空格 
    9.         if (string == " ") { 
    10.             return false 
    11.         } 
    12.   
    13.         //按下回车后取消键盘 
    14.         if (string == " ") { 
    15.             textField.resignFirstResponder() 
    16.             return false 
    17.         } 
    18.   
    19.         return true 
    20.     } 

    UITextView代码如下:

    1. //设置代理,可根据实际情况来设置代理,这里使用self来指定 
    2. self.textView.delegate = self 
    3.   
    4. //代理方法实现 
    5. func textView(textView: UITextView, shouldChangeTextInRange range: NSRange,  
    6. replacementText text: String) -> Bool 
    7.     { 
    8.         //禁止输入空格 
    9.         if (text == " ") { 
    10.             return false 
    11.         } 
    12.   
    13.         //按下回车后取消键盘 
    14.         if (text == " ") { 
    15.             textView.resignFirstResponder() 
    16.             return false 
    17.         } 
    18.   
    19.         return true 
    20.     } 

    UITextField/UITextView可以通过代理方法实时检测用户输入的内容,方便对输入约束,例如,在输入超过10个字符时,禁止用户输入,不过这种体验不好,建议不要使用
    四、响应编程处理,精确提示信息
    1、如何优化

    输入信息的约束一般是将规则直接提示给用户,例如:社交中用户昵称的输入:

    请输入1-8位的字符作为昵称,不能包括空格、回车、标点

    用户点击**确定**按钮之后,检查输入的合法性,并通过对话框(或HUD)的形式,提示给用户信息

    上面的处理方式,十分常见,能满足基本需求。不过我们已经不再采用上面的设计,原因有以下两点:

    提示信息过多,大部分用户不会看

    对话框及HUD提示比较突兀,容易使用户产生挫败感

    在实际开发过程中,精减提示信息为

    1. 请输入1-8个字符 

    用户主动输入空格、回车、标点这些字符或者超出长度时,才主动提示给用户信息,如下图,无输入,确定按钮disable,只提示极少有用信息

    输入合法,确定按钮enable

    输入不合法,高亮错误显示,确定按钮disable

    2、代码实现

    使用第三方框架ReactiveCocoa,首先实现在用户输入时,下方提示及右侧图片的功能(不使用三方框架,可自己通过代理实现)

    1. @IBOutlet weak var nickTextField: UITextField!//文本输入框 
    2.     @IBOutlet weak var checkResultShowImageView: UIImageView!//输入框右侧图片 
    3.     @IBOutlet weak var button: UIButton! 
    4.     @IBOutlet weak var hintLabel: UILabel!//文本框下方提示文字 
    5.   
    6.     override func viewDidLoad() { 
    7.         super.viewDidLoad() 
    8.         //配置输入 
    9.         configInput()     
    10.     } 
    11.   
    12.  func configInput() { 
    13.         self.nickTextField.rac_textSignal().subscribeNext { (text) -> Void in 
    14.             if (text == nil || text.length == 0) { 
    15.                 self.checkResultShowImageView.hidden = false 
    16.                 return 
    17.             } 
    18.   
    19.             self.checkResultShowImageView.hidden = true 
    20.             var imageName = "" 
    21.             if (self.checkInputValidate()) { 
    22.                 imageName = "ok.png" 
    23.                 self.hintLabel.text = "" 
    24.             } else { 
    25.                 imageName = "warning.png" 
    26.                 self.hintLabel.text = "超出(text.length - 8)个字符" 
    27.             } 
    28.             self.checkResultShowImageView.image = UIImage(named: imageName) 
    29.   
    30.         } 
    31.     } 
    32.   
    33.     func checkInputValidate() -> Bool { 
    34.         //输入条件检查,这里示例,只检查字符长度 
    35.         let length = (self.nickTextField.text as NSString).length 
    36.         return length > 0 && length <= 
    37.     } 

    下面实现功能:根据输入的合法性,设置按钮的enabled属性,此步骤需要下载文件RAC语法支持文件,更详细介绍Swift支持ReactiveCocoa

    1. func configButtonEnable() { 
    2.         RAC(self.button, "enabled") < ~ RACSignal.combineLatest( 
    3.             [self.nickTextField.rac_textSignal()], 
    4.             reduce: { () -> AnyObject! in 
    5.   
    6.             return self.checkInputValidate() 
    7.   
    8.         }) 
    9.     } 

    五、中文处理办法

    有中文输入时,上面的字数检查不准确,如通过输入法输入**"我爱中国文化"**6个字符时self.nickTextField.text的字符个数为23个,提示信息不正确

    UITextView/UITextFiled有一个markedTextRange属性,用于标识当前是否有选中的文本(有选中文本时即为上图中的未完成输入状态),利用此原理来解决中文等类似问题

    1. @IBOutlet weak var nickTextField: UITextField! 
    2.     @IBOutlet weak var checkResultShowImageView: UIImageView! 
    3.     @IBOutlet weak var button: UIButton! 
    4.     @IBOutlet weak var hintLabel: UILabel! 
    5.   
    6.     var chineseText: NSString! 
    7.   
    8.     override func viewDidLoad() { 
    9.         super.viewDidLoad() 
    10.         self.nickTextField.delegate = self 
    11.         filterInput() 
    12.         configButtonEnable() 
    13.   
    14.   
    15.     } 
    16.   
    17.     func filterInput() { 
    18.         self.nickTextField.rac_textSignal().subscribeNext { (text) -> Void in 
    19.             if(self.nickTextField.markedTextRange != nil) { 
    20.                 return; 
    21.             } 
    22.             //这里可以加入去除空格,标点等操作 
    23.             self.chineseText = text as NSString 
    24.   
    25.             if (text == nil || text.length == 0) { 
    26.                 self.checkResultShowImageView.hidden = false 
    27.                 return 
    28.             } 
    29.   
    30.             self.checkResultShowImageView.hidden = true 
    31.             var imageName = "" 
    32.             if (self.checkInputValidate()) { 
    33.                 imageName = "ok.png" 
    34.                 self.hintLabel.text = "" 
    35.             } else { 
    36.                 imageName = "warning.png" 
    37.                 self.hintLabel.text = "超出(text.length - 8)个字符" 
    38.             } 
    39.             self.checkResultShowImageView.image = UIImage(named: imageName) 
    40.   
    41.         } 
    42.     } 
    43.   
    44.     func checkInputValidate() -> Bool { 
    45.         //输入条件检查,这里示例,只检查字符长度 
    46.         let length = chineseText.length 
    47.         return length > 0 && length < = 
    48.     } 
    49.   
    50.     func configButtonEnable() { 
    51.         RAC(self.button, "enabled") < ~ RACSignal.combineLatest( 
    52.             [self.nickTextField.rac_textSignal()], 
    53.             reduce: { () -> AnyObject! in 
    54.   
    55.             if(self.nickTextField.markedTextRange == nil) { 
    56.                 return self.checkInputValidate() 
    57.             } 
    58.             return self.button.enabled 
    59.   
    60.         }) 
    61.     } 
    62.   
    63.   
    64.     @IBAction func buttonPressed(sender: AnyObject) { 
    65.         println("------>(self.chineseText)") 
    66.     } 

    六、总结

    输入是手机App中最耗时的操作,处理不当很容易失去用户,这里总结以下几点

    不要将所有的约束信息直接展示给用户,只展示那些对大部分用户都有用的信息,对于其他约束在用户输入错误的时候再提示

    尽量少用或者不用对话框及HUD的方式提示错误

    提示信息准确,例如超出字符数,一种提示为:超出最大140字符;另一种为:超出n个字符,显然后者提示对用户更有价值

    不要擅自更改用户输入内容或者粗暴禁止用户输入

  • 相关阅读:
    第32章 数据库的备份和恢复
    Perl 打印关键字上下行
    mysql select * into OUTFILE 不会锁表
    独享表空间 ibdata1
    sql 使用单引号
    Oracle 维护常用SQL
    Mysql 独享表空间
    Mysql Perl unload表数据
    PLSQL 拼接SQL
    begin和declare
  • 原文地址:https://www.cnblogs.com/Free-Thinker/p/4834826.html
Copyright © 2020-2023  润新知