使用UIPickerView实现简单的城市选择器

来源:互联网 发布:袁隆平害了中国人知乎 编辑:程序博客网 时间:2024/06/05 05:26

UIPickerView是apple提供的选择器控件,可以根据业务需求生成单列或多列的选择器.
下面举例实现一个”省份-城市”联动的两列选择器.

查看源码(oc+swift)

效果图

效果图

数据源格式

因为只是一个简单的示例,所以在网上随便找了一个plist文件,数据格式截图如下:
数据格式

实现思路

与UITableView一样,UIPickerView需要开发者实现其UIPickerViewDataSourceUIPickerViewDelegate协议.

UIPickerViewDataSource

UIPickerViewDataSource包含两个必须要实现的数据源方法numberOfComponentsInPickerViewnumberOfRowsInComponent,分别用来告诉系统我们实现的选择器有几列,每一列又有多少行.

由于我们要实现的是省份-城市二级联动效果,所以在第一个方法中返回2,而针对每一个省份对应着不同的城市,当滚动第一列省份列表时,第二列的城市列表要对应刷新,所以我们需要一个cityArray数组来保存当前省份对应的城市.这样,在滚动省份时只需要刷新第二列的数据即可.

UIPickerViewDelegate

UIPickerViewDelegate主要包含了返回pickerView宽高及响应选择事件的方法.
注意,UIPickerView有默认高度,代码设置高度是无效的.
实现省份-城市的列表联动主要是处理pickerView:didSelectRow:inComponent:方法,当省份选择时,刷新城市列表,并将城市列表滚动到第一列.

0 0
原创粉丝点击