一次UITextView失焦保存所引发的思考

因为项目是属于效率工作类软件,程序中大量界面都涉及到了实时的数据保存。昨天做任务标题实时保存时处理的不大好,这里记录一下。

Snip20170823_17.png

如图 有三个数据处理项。一个是完成按钮 一个是标题 一个是任务下发成员。除了标题之外,其余两个都很好做。比如完成按钮 切换选中状态的时候就可以发送网络请求给服务器,下发成员从成员控制器返回后可以发送请求给服务器。

对于标题而言。如果做实时保存的话明显不大可行,总不可能标题一变就发送请求。那你输入的时候 是不是一直会发送网络请求呢。所以我选择了失焦保存去处理。也就是说用户在输入的时候不做处理,当用户输入完了,UITextView失去焦点的时候发生请求给服务器保存数据。但这会导致一个问题,如果用户输入完标题后,立马点击左上角的返回保存按钮,此时并不会立即触发失焦事件,而是先触发返回事件,这样的话控制器销毁了,对应的失焦事件代码也不会再执行了。

为了解决这个问题,我第一次处理的方法是加了一个变量,实时记录标题。在返回的时候再保存一次。

Snip20170823_21.png
Snip20170823_20.png

这样完全可以解决问题。但是不好的点在于,当用户输入完标题后并没有立即点击返回按钮,而是操作了任务的其他功能项,触发失焦事件保存当前标题,这样返回的时候会多一次保存。这种解决思路并不好。

今天无意中看到笔记模块自己之前写的代码,发现这个问题只需要用一句代码就可以完美解决:【self.view endEditing:YES】

Snip20170823_22.png

这样既可以避免重复保存的情况出现,又可以洁简代码。

后来我想了一下,这句代码我一直在用。但是为什么出现问题的时候我并没有第一时间想到这个。因为我在一开始想问题的时候方向就错了。

既然问题是因为用户输入完标题后直接返回 会先触发返回事件,从而导致失焦保存方法不执行,我不应该去想在返回事件里处理一下这种特殊情况。我应该想的是避免这种特殊情况。这是很重要的一点,通俗来讲,就是遇到一种特殊情况,我们首先考虑的应该是避免这种情况的发生而不是加一堆无意义的代码去处理这种情况。放在我的项目里来说,也就是在返回之前让页面的所有view结束编辑状态,这样就可以在返回之前触发失焦事件,这才是问题最好的解决思路。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 11,132评论 6 13
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,223评论 4 61
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,886评论 18 139
  • 感恩上午滴滴司机配合我绕路安置宝宝,然后再配合我赶时间,一路疾驰到学校,刚刚好上课。感恩一路的畅通无阻!感觉好安心...
    莞尔的人生阅读 395评论 0 5
  • 放的下的,放不下的。留的住的,留不住的。 一大一小,一忙一闲。让自己忙起来,很多事情就已经解决了,很多很多事情,也...
    庄德坤阅读 242评论 0 0