IOS第11天(3:UIPickerView省市联动)

*********

#import "ViewController.h"
#import "Province.h"

@interface ViewController ()<UIPickerViewDataSource,UIPickerViewDelegate>

@property (nonatomic,strong)NSArray *provinces;

@property (nonatomic,assign)NSInteger indexOfProvice;//当前默认选中的省份
@end

@implementation ViewController

-(NSArray *)provinces{
    if (!_provinces) {
        _provinces = [Province provinceList];
    }

    return _provinces;
}

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view, typically from a nib.
    NSLog(@"%@",self.provinces);
}

// returns the number of ‘columns‘ to display.
- (NSInteger)numberOfComponentsInPickerView:(UIPickerView *)pickerView{
    return 2;
}

// returns the # of rows in each component..
- (NSInteger)pickerView:(UIPickerView *)pickerView numberOfRowsInComponent:(NSInteger)component{

    if (component == 0) {//省分
        return self.provinces.count;
    }

    //获取对应省份的城市个数
    Province *province = self.provinces[self.indexOfProvice];

    return province.cities.count;

}

#pragma mark 显示数据
-(NSString *)pickerView:(UIPickerView *)pickerView titleForRow:(NSInteger)row forComponent:(NSInteger)component{

    if(component == 0){//显示省份的名字
        //对应列行的省份
        Province *province = self.provinces[row];
        return province.name;
    }

    //获取选中的城市,显示城市名字
    Province *selectedProvice = self.provinces[self.indexOfProvice];
    return selectedProvice.cities[row];
}

//-(UIView *)pickerView:(UIPickerView *)pickerView viewForRow:(NSInteger)row forComponent:(NSInteger)component reusingView:(UIView *)view{
//
//    UILabel *label = (UILabel *)view;
//    if (!label) {
//        label = [[UILabel alloc] init];
//    }
//
//    if(component == 0){//显示省份的名字
//        //对应列行的省份
//        Province *province = self.provinces[row];
//        label.text =  province.name;
//        label.backgroundColor = [UIColor grayColor];
//    }else{
//
//        //获取选中的城市,显示城市名字
//        Province *selectedProvice = self.provinces[self.indexOfProvice];
//        label.text = selectedProvice.cities[row];
//        label.backgroundColor = [UIColor blueColor];
//    }
//
//
//
//
//    return label;
//}

#pragma mark 选中行

-(void)pickerView:(UIPickerView *)pickerView didSelectRow:(NSInteger)row inComponent:(NSInteger)component{

    if (component == 0) {//第一列省的选中改变后,就要更新第二列数据
        //更新选中省份的索引
        self.indexOfProvice = row;

        //刷新数据
        //全部刷新
        //[pickerView reloadAllComponents];

        //部份刷新
        [pickerView reloadComponent:1];

        //不管之前第二列选中第几行,重新刷新数据后,都显示每二列的第一行
        [pickerView selectRow:0 inComponent:1 animated:YES];
    }
}

#pragma mark 设置宽度
-(CGFloat)pickerView:(UIPickerView *)pickerView widthForComponent:(NSInteger)component{
    if (component == 0) {
        return 80;
    }

    return 200;
}

@end

***model.m

#import "Province.h"

@implementation Province

-(instancetype)initWithDict:(NSDictionary *)dict{
    if (self = [super init]) {
        [self setValuesForKeysWithDictionary:dict];
    }

    return self;
}
+(instancetype)provinceWithDict:(NSDictionary *)dict{
    return [[self alloc] initWithDict:dict];
}

+(NSArray *)provinceList{
    //plist文件路径
    NSString *filePath = [[NSBundle mainBundle] pathForResource:@"provinces.plist" ofType:nil];
    NSArray *provincePlist = [NSArray arrayWithContentsOfFile:filePath];

    NSMutableArray *provinceM = [NSMutableArray array];
    for (NSDictionary *dic in provincePlist) {
        Province *prov = [Province provinceWithDict:dic];
        [provinceM addObject:prov];
    }

    return provinceM;

}
@end

****model.h

#import <UIKit/UIKit.h>

@interface Province : NSObject

@property(nonatomic,copy)NSString *name;
@property(nonatomic,strong)NSArray *cities;

-(instancetype)initWithDict:(NSDictionary *)dict;
+(instancetype)provinceWithDict:(NSDictionary *)dict;

+(NSArray *)provinceList;

@end
时间: 2024-10-17 12:50:21

IOS第11天(3:UIPickerView省市联动)的相关文章

IOS第11天(1:UIPickerView点餐)

UIPickerView #import "ViewController.h" @interface ViewController ()<UIPickerViewDataSource,UIPickerViewDelegate> @property (nonatomic,strong)NSArray *foods; @property (weak, nonatomic) IBOutlet UILabel *fruitLabel; @property (weak, nonato

IOS第11天(2:UIPickerView自定义国旗选择)

国旗选择 #import "HMViewController.h" #import "HMFlag.h" #import "HMFlagView.h" @interface HMViewController ()<UIPickerViewDataSource,UIPickerViewDelegate> @property(nonatomic,strong)NSArray *flags; @end @implementation HMV

iOS.UIKit.11.UIPickerView

一.案例介绍:点击UIButton,将选中的省市信息显示在UILabel中,如图01,02 图01图02 二.案例步骤: 1.选择Simple View Aplication,取名cq.37.普通选择器,如图03 图03 2.Main.storyboard,如图04 3.provinces_cities.plist 4.CQ37ViewController.h #import <UIKit/UIKit.h> @interface CQ37ViewController : UIViewContr

IOS TableView实现省市联动

之前用UIPickerView实现了省市联动,上个月网友让用UITableView给他实现了下.今天也把这些贴出来. // // ViewController.m // doubleTable // // Created by City--Online on 15/8/5. // Copyright (c) 2015年 City--Online. All rights reserved. // #import "ViewController.h" @interface ViewCont

php省市联动实现

设计模式:ajax实现,数据库格式:id,name,parent_id 数据库: CREATE TABLE IF NOT EXISTS `city` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(30) DEFAULT NULL, `parent_id` int(11) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREME

jquery插件-省市联动

由于项目需要需要实现一个省市联动,由于业务有一些特殊的需求,使用现有的插件略有不便,就自己实现了一个. 首先需要保存地区数据的JS数据文件,我这里命名为areaData.js,内容如下: /** * 保存地区信息 * 数据格式 * areaData = [{'pro': '北京', 'cities': {'-1': '北京'}}, {...}] * 直辖市存在-1,表示就是直辖市 */ (function(window) { window.areaData = [{"pro":&quo

Dynamic CRM 2013学习笔记(八)过滤查找控件 (类似省市联动)

我们经常要实现类似省市联动一样的功能,常见的就是二个查找控件,一个选择了省后,另一个市的查找控件就自动过滤了,只显示当前省下的市,而不是所有的市.当然这是最简单的,实际工作中还有更复杂的功能要通过过滤查找控件来实现.本文主要介绍基本的查找控件过滤.多表关联的复杂过滤以及子表里实现查找控件的过滤.   一.简单的过滤 先看下需求: 按"Special GL Indicator" 来过滤 Posting 查找控件增加了preSearch事件.它发生在查找控件显示对话框供用户查找记录之前,与

AJAX案例四:省市联动

1 <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> 2 <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> 3 4 5 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4

js实现的省市联动

最近工作,要用到省市联动的功能.网上搜了一下,发现有很多这样的例子,看了不少实例,把觉得写得不错的代码穿上来,好给大家分享一下. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/199