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

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

查看源码(oc+swift)

效果图

数据源格式

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

实现思路

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

UIPickerViewDataSource

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

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

UIPickerViewDelegate

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

相关文章

软件简介:蓝湖辅助工具,减少移动端开发中控件属性的复制和粘...
现实生活中,我们听到的声音都是时间连续的,我们称为这种信...
前言最近在B站上看到一个漂亮的仙女姐姐跳舞视频,循环看了亿...
【Android App】实战项目之仿抖音的短视频分享App(附源码和...
前言这一篇博客应该是我花时间最多的一次了,从2022年1月底至...
因为我既对接过session、cookie,也对接过JWT,今年因为工作...