Swift社交应用文本输入优化汇总.docx

上传人:b****8 文档编号:11384434 上传时间:2023-02-28 格式:DOCX 页数:13 大小:100.08KB
下载 相关 举报
Swift社交应用文本输入优化汇总.docx_第1页
第1页 / 共13页
Swift社交应用文本输入优化汇总.docx_第2页
第2页 / 共13页
Swift社交应用文本输入优化汇总.docx_第3页
第3页 / 共13页
Swift社交应用文本输入优化汇总.docx_第4页
第4页 / 共13页
Swift社交应用文本输入优化汇总.docx_第5页
第5页 / 共13页
点击查看更多>>
下载资源
资源描述

Swift社交应用文本输入优化汇总.docx

《Swift社交应用文本输入优化汇总.docx》由会员分享,可在线阅读,更多相关《Swift社交应用文本输入优化汇总.docx(13页珍藏版)》请在冰豆网上搜索。

Swift社交应用文本输入优化汇总.docx

Swift社交应用文本输入优化汇总

Swift社交应用文本输入优化汇总

一、输入相关的优化问题

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

本文将汇总一下Swift社交应用文本输入优化技巧。

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

输入控件UITextField跟随键盘移动

过滤输入内容

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

中文输入

二、输入框随键盘移动

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

TPKeyboardAvoiding

1、代码处理方法

rootView使用**TPKeyboardAvoiding**框架中的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 == "\n") { 

15.            textField.resignFirstResponder() 

16.            return false 

17.        } 

18.  

19.        return true 

20.    } 

(2)UITextView代码如下:

1.self.textView.delegate = self 

2.  

3.//代理方法实现 

4.func textView(textView:

 UITextView, shouldChangeTextInRange range:

 NSRange,  

5.replacementText text:

 String) -> Bool 

6.    { 

7.        //禁止输入空格 

8.        if (text == " ") { 

9.            return false 

10.        } 

11.  

12.        //按下回车后取消键盘 

13.        if (text == "\n") { 

14.            textView.resignFirstResponder() 

15.            return false 

16.        } 

17.  

18.        return true 

19.    } 

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 <= 8 

37.   } 

下面实现功能:

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

1.func configButtonEnable() { 

2.        RAC(self.button, "enabled") < ~ RACSbineLatest( 

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 < = 8 

48.    } 

49.  

50.    func configButtonEnable() { 

51.        RAC(self.button, "enabled") < ~ RACSbineLatest( 

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个字符,显然后者提示对用户更有价值

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

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 初中教育 > 语文

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1