UIPickerView选择“省市区”

本文旨在为大家提供“干货”,在文章结尾会提供Demo下载地址。本文内容简单,但实用价值高,有需要的自取,并关注我!大牛可绕行。后续Richy将定期为大家更新...

闲话不多说了,先给大家看效果展示:

UIPickerView选择“省市区”_第1张图片

纵观该例子,用到的知识点仅有UIPickerView结合数据源的使用,但是Richy花费了很长时间才完成。其中90%的时间用于手动录入Province.plist(各省市区的信息),虽然说录入数据的过程参考了网上已公开的现成的Address.plist(PS:非常感谢共享次内容的GG/MM),但是重构plist内部结构依然是个繁重的工程,因此各位客官要体谅Richy的辛劳。


Now,Richy介绍一下实现的思路:

一、UIPickerView的使用

1. UIPickerView的创建

UIPickerView选择“省市区”_第2张图片

2. 遵守两个协议:

3. 常用各协议下的方法:

UIPickerView选择“省市区”_第3张图片

4.其他方法:

UIPickerView选择“省市区”_第4张图片

二、数据源 Province.plist的结构

UIPickerView选择“省市区”_第5张图片

关键的Key值定义如下:

省:Province;

市:city

区:districts

举个Demo中的例子帮大家理解,如下图:

UIPickerView选择“省市区”_第6张图片

咱们一起看一下最复杂的一个(前提:熟悉plist的结构),那么其他的就是小case了。

return [self.arrayDS[_provinceIndex][@"citys"][_cityIndex][@"districts"] count];

首先,这行内容代表的涵义是返回第3列的行数;

其次,当操作第3列时说明,第1和2列是确定的,故通过两个Index记录其选中的行;

最后,结果即某一省(self.arrayDS[_provinceIndex])中的某一市(self.arrayDS[_provinceIndex][@"citys"][_cityIndex])中的所有区(self.arrayDS[_provinceIndex][@"citys"][_cityIndex][@"districts"])的总数量([self.arrayDS[_provinceIndex][@"citys"][_cityIndex][@"districts"] count])。

三、细节问题处理

1. 三列之间是紧密相关的,操作第1列时,第2和3列会随之发生改变;而操作第2列的时候,第3列会随之发生改变,但第1列确实固定的;而操作第3列的时候,第1和2列均固定。

2. 基于上边内容,从而决定了你什么时间记录省市区的选中Index(eg:_cityIndex = row;),同时也决定了你什么时间重置数据(eg: _districtIndex = 0;)以及刷新数据展示(-reloadComponent),具体见下图:

UIPickerView选择“省市区”_第7张图片

四、最后,感谢大家坚持看完本文。您的鼓励和支持是Richy的动力源泉。


UIPickerView选择“省市区”_第8张图片

地址:http://www.jianshu.com/users/76e87d7d8887/latest_articles

GitHub:https://github.com/RichyLeo

Demo下载地址:https://github.com/RichyLeo/ProvincePickerView.git

你可能感兴趣的:(UIPickerView选择“省市区”)