iOS開(kāi)發(fā)之UIPickerView實(shí)現(xiàn)城市選擇器的步驟詳解
前言
UIPickerView是一個(gè)選擇器控件,它可以生成單列的選擇器,也可生成多列的選擇器,而且開(kāi)發(fā)者完全可以自定義選擇項(xiàng)的外觀,因此用法非常靈活。UIPickerView直接繼承了UIView,沒(méi)有繼承UIControl,因此,它不能像UIControl那樣綁定事件處理方法,UIPickerView的事件處理由其委托對(duì)象完成。
本文借助于UIPickerView來(lái)實(shí)現(xiàn)城市選擇器,第一列為省份,第二列為第一列省份對(duì)應(yīng)的城市或者區(qū),數(shù)據(jù)放在plist中,plist結(jié)構(gòu)如下圖所示,第一層是一個(gè)Dictionary,每個(gè)省份對(duì)應(yīng)的城市是一個(gè)Array:
實(shí)現(xiàn)步驟
第一步
拖入一個(gè)UIPickerView
到StoryBoard
中,然后設(shè)置UIPickerViewDelegate
,和UIPickerViewDataSource
為當(dāng)前的控制器,如下圖紅色區(qū)域所示:
設(shè)置數(shù)據(jù)源與代理
第二步
在對(duì)應(yīng)的ViewController
中進(jìn)行實(shí)現(xiàn),代碼注釋非常詳細(xì)
#import "ViewController.h" @interface ViewController () <UIPickerViewDelegate, UIPickerViewDataSource> /** * plist對(duì)應(yīng)的字典 */ @property (nonatomic, strong) NSDictionary* cityNames; /** * 省份 */ @property (nonatomic, strong) NSArray* provinces; /** * 城市 */ @property (nonatomic, strong) NSArray* cities; @end @implementation ViewController /** * 懶加載plist * * @return plist對(duì)應(yīng)的字典 */ - (NSDictionary*)cityNames { if (_cityNames == nil) { NSString* path = [[NSBundle mainBundle] pathForResource:@"cityData" ofType:@"plist"]; _cityNames = [NSDictionary dictionaryWithContentsOfFile:path]; } return _cityNames; } /** * 懶加載省份 * * @return 省份對(duì)應(yīng)的數(shù)組 */ -(NSArray *)provinces { if (_provinces == nil) { //將省份保存到數(shù)組中 _provinces = [self.cityNames allKeys]; } return _provinces; } - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typically from a nib. } - (void)didReceiveMemoryWarning { [super didReceiveMemoryWarning]; // Dispose of any resources that can be recreated. } /** * 返回每一列的行數(shù) * * @param pickerView * @param component * * @return */ - (NSInteger)pickerView:(UIPickerView*)pickerView numberOfRowsInComponent:(NSInteger)component { if (component == 0) { return self.provinces.count; } else { [self loadData:pickerView]; return self.cities.count; } } /** * 返回每一行顯示的文本 * * @param pickerView * @param row * @param component * * @return */ - (NSString*)pickerView:(UIPickerView*)pickerView titleForRow:(NSInteger)row forComponent:(NSInteger)component { //第一列返回所有的省份 if (component == 0) { return self.provinces[row]; } else { [self loadData:pickerView]; return self.cities[row]; } } /** * 加載第二列顯示的數(shù)據(jù) * * @param pickerView */ -(void)loadData:(UIPickerView*)pickerView { //一定要首先獲取用戶選擇的那一行 然后才可以根據(jù)選中行獲取省份 獲取省份以后再去字典中加載省份對(duì)應(yīng)的城市 NSInteger selRow = [pickerView selectedRowInComponent:0]; NSString *key = self.provinces[selRow]; self.cities = [self.cityNames valueForKey:key]; } /** * 一共多少咧 * * @param pickerView * * @return */ - (NSInteger)numberOfComponentsInPickerView:(UIPickerView*)pickerView { return 2; } /** * 選中某一行后回調(diào) 聯(lián)動(dòng)的關(guān)鍵 * * @param pickerView * @param row 用戶選擇的省份 * @param component */ - (void)pickerView:(UIPickerView*)pickerView didSelectRow:(NSInteger)row inComponent:(NSInteger)component { if (component == 0) { //重新加載第二列的數(shù)據(jù) [pickerView reloadComponent:1]; //讓第二列歸位 [pickerView selectRow:0 inComponent:1 animated:YES]; } } @end
實(shí)現(xiàn)效果
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流。
相關(guān)文章
IOS實(shí)現(xiàn)視頻動(dòng)畫效果的啟動(dòng)圖
這篇文章實(shí)現(xiàn)的是一個(gè)關(guān)于啟動(dòng)頁(yè)或者引導(dǎo)頁(yè)的視頻動(dòng)畫效果的實(shí)現(xiàn)過(guò)程,對(duì)于大家開(kāi)發(fā)APP具有一定的參考借鑒價(jià)值,有需要的可以來(lái)看看。2016-09-09IOS 聊天界面(自適應(yīng)文字)的實(shí)現(xiàn)
本文主要介紹一個(gè)實(shí)現(xiàn)聊天界面的思路過(guò)程,具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧2017-03-03iOS開(kāi)發(fā)中常見(jiàn)的項(xiàng)目文件與MVC結(jié)構(gòu)優(yōu)化思路解析
這篇文章主要介紹了iOS開(kāi)發(fā)中常見(jiàn)的項(xiàng)目文件與MVC結(jié)構(gòu)優(yōu)化思路解析,示例代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下2015-12-12iOS CoreTelephony 實(shí)現(xiàn)監(jiān)聽(tīng)通話狀態(tài)
這篇文章主要介紹了iOS CoreTelephony 實(shí)現(xiàn)監(jiān)聽(tīng)通話狀態(tài) 的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-07-07IOS 解決UIButton 點(diǎn)擊卡頓/延遲的問(wèn)題
本文主要介紹 IOS UIButton, 這里給大家提供代碼實(shí)例作為參考,解決 UIButton 點(diǎn)擊卡頓或者延遲問(wèn)題,在開(kāi)發(fā) IOS 項(xiàng)目的小伙伴如果遇到這樣的問(wèn)題可以參考下2016-07-07