前几天用UIPickerView实现了一下三级联动具体的如下图

下面是实现方式

#import "ViewController.h"

#define FirstComponent

#define SubComponent

#define ThirdComponent

@interface ViewController ()

@property(nonatomic,retain)NSDictionary* dict;

@property(nonatomic,retain)NSArray* pickerArray;

@property(nonatomic,retain)NSArray* subPickerArray;

@property(nonatomic,retain)NSArray* thirdPickerArray;

@property(nonatomic,retain)NSArray* selectArray;

@end

@implementation ViewController

@synthesize dict=_dict;

@synthesize pickerArray=_pickerArray;

@synthesize subPickerArray=_subPickerArray;

@synthesize thirdPickerArray=_thirdPickerArray;

@synthesize selectArray=_selectArray;

- (void)viewDidLoad

{

[superviewDidLoad];

// Do any additional setup after loading the view, typically from a nib.

NSString* plistPath=[[NSBundle mainBundle] pathForResource:@"Address" ofType:@"plist"];

_dict=[[NSDictionary alloc] initWithContentsOfFile:plistPath];

self.pickerArray=[_dict allKeys];

self.selectArray=[_dict objectForKey:[[_dict allKeys] objectAtIndex:0]];

if ([_selectArray count]>0) {

self.subPickerArray= [[self.selectArray objectAtIndex:0] allKeys];

}

if ([_subPickerArraycount]>0)
{

self.thirdPickerArray=[[self.selectArray objectAtIndex:0] objectForKey:[self.subPickerArray objectAtIndex:0]];

}

}

- (void)didReceiveMemoryWarning

{

[superdidReceiveMemoryWarning];

// Dispose of any resources that can be recreated.

}

#pragma mark --

#pragma mark--UIPickerViewDataSource

-(NSInteger)numberOfComponentsInPickerView:(UIPickerView *)pickerView

{

return3;

}

-(NSInteger)pickerView:(UIPickerView *)pickerView numberOfRowsInComponent:(NSInteger)component

{

if (component==FirstComponent) {

return [self.pickerArray count];

}

if (component==SubComponent) {

return [self.subPickerArray count];

}

if (component==ThirdComponent) {

return [self.thirdPickerArray count];

}

return0;

}

#pragma mark--

#pragma mark--UIPickerViewDelegate

-(NSString *)pickerView:(UIPickerView *)pickerView titleForRow:(NSInteger)row
forComponent:(NSInteger)component

{

if (component==FirstComponent) {

return [self.pickerArray objectAtIndex:row];

}

if (component==SubComponent) {

return [self.subPickerArray objectAtIndex:row];

}

if (component==ThirdComponent) {

return [self.thirdPickerArray objectAtIndex:row];

}

return
nil;

}

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

{

NSLog(@"row is %d,Component is %d",row,component);

if (component==0) {

self.selectArray=[_dict objectForKey:[self.pickerArray objectAtIndex:row]];

if ([self.selectArray count]>0)
{

self.subPickerArray= [[self.selectArray objectAtIndex:0] allKeys];

}else{

self.subPickerArray=nil;

}

if ([self.subPickerArraycount]>0)
{

self.thirdPickerArray=[[self.selectArray objectAtIndex:0] objectForKey:[self.subPickerArray objectAtIndex:0]];

}else{

self.thirdPickerArray=nil;

}

[pickerView selectedRowInComponent:1];

[pickerView reloadComponent:1];

[pickerView selectedRowInComponent:2];

}

if (component==1) {

if ([_selectArraycount]>0&&[_subPickerArraycount]>0)
{

self.thirdPickerArray=[[self.selectArray objectAtIndex:0] objectForKey:[self.subPickerArray objectAtIndex:row]];

}else{

self.thirdPickerArray=nil;

}

[pickerView selectRow:0 inComponent:2 animated:YES];

}

[pickerView reloadComponent:2];

}

- (CGFloat)pickerView:(UIPickerView *)pickerView widthForComponent:(NSInteger)component

{

if (component==FirstComponent) {

return90.0;

}

if (component==SubComponent) {

return120.0;

}

if (component==ThirdComponent) {

return100.0;

}

return0;

}

-(void)dealloc

{

self.dict=nil;

self.pickerArray=nil;

self.subPickerArray=nil;

self.thirdPickerArray=nil;

self.selectArray=nil;

[superdealloc];

}

@end

UIPickerView实现省 市 区三级联动的更多相关文章

  1. html实现 省——市——区三级联动

    html实现  省——市——区三级联动 html中实现三级联动是一个不错的demo,博主在这里跟大家分享一下实现的过程,以及自己在过程中出现的一些问题,仅供参考. 首先我们将全国的省市区数据导入进来, ...

  2. jqeury-地区三级联动

    html+js <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www ...

  3. AJAX实现三级联动

    省市区三级联动插件: 主页面:为方便使用,不用写过多代码,只写一个id为sanji的div,若别的页面要用,只需写一个id为sanji的div,加载上jQuery与sanji.js文件即可 <! ...

  4. 使用php ajax写省、市、区、三级联动

    题目要求: 要求:写一个省市区(或者年月日)的三级联动,实现地区或时间的下拉选择. 实现技术:php ajax 实现:省级下拉变化时市下拉区下拉跟着变化,市级下拉变化时区下拉跟着变化. 使用china ...

  5. 使用 AJAX + 三级联动 实现分类出全国各地的省,市,区

    使用AJAX + 三级联动  实现分类出全国各地的省,市,区 也可以将下面的显示页面所写的 function循环,封装成js文件,就是在写代码软件里创建一个js文件,就和创建一个HTML或php文件一 ...

  6. jQuery三级联动效果代码(省、市、区)

    很长时间都不用jquery了,有人问我jquery写三级联动的插件我就写好了发出来吧,正好需要的人都可以看看. 一.html代码 <!DOCTYPE html> <html> ...

  7. ajax(省,市,县)三级联动

    下面我们用Jquery,ajax,做一个省,市,县的三级联动: 下面是我做三级联动下拉的步骤以及逻辑 第一步:先做一个省市区表格 第二步:建个PHP页面显示用我是在<body>里放< ...

  8. javascript 省、市、地县三级联动

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"><HTML><HEAD&g ...

  9. vue+element实现省区市三级联动以及详细地址的输入

    Vue+elementui实现省区市三级联动+详细地址的输入 详细需求,需要手动更改用户所在的地址. 安装依赖项 npm install element-china-area-data -S 在组建中 ...

随机推荐

  1. 【HDOJ】1026 Ignatius and the Princess I

    这道题搞了很久啊.搜索非常好的一道题.昨天想了2小时,以为是深搜,但后来发现深搜怎么也没法输出正确路径.今天拿宽搜试了一下,问题就是普通的队列宽搜没法得到当前时间最小值.看了一下讨论区,发现优先级队列 ...

  2. JavaScript里的类和继承

    JavaScript与大部分客户端语言有几点明显的不同: JS是 动态解释性语言,没有编译过程,它在程序运行过程中被逐行解释执行JS是 弱类型语言,它的变量没有严格类型限制JS是面向对象语言,但 没有 ...

  3. 教您Photoshop中如何快速放大、缩小、移动图像

    教您Photoshop中如何快速放大.缩小.移动图像 http://jingyan.baidu.com/article/ae97a646aaeaaebbfc461d5e.html

  4. bootstrap基本标签总结[转]

    文件头: DOCTYPE HTML> <html> <head> <meta charset="utf-8"> <title> ...

  5. JSP---JavaBean的使用-jsp:useBean标签相关

    JavaBean介绍: JavaBean其实就是一个遵循特定写法的java类,但是必须具有如下特点: 1.这个java类必须具有一个公开的无参构造函数 2.属性必须私有化,类必须公开 3.私有化的属性 ...

  6. NOIP2015 斗地主(搜索+剪枝)

    4325: NOIP2015 斗地主 Time Limit: 30 Sec  Memory Limit: 1024 MBSubmit: 270  Solved: 192[Submit][Status] ...

  7. Azure VM对远程桌面登录的支持-示例

    我们在开发Windows Azure的应用程序,虽然在大部分的情况下都可以使用Azure Emulator模拟器来模拟在云端计算节点(Azure VM)的执行结果,但是并不能100%模拟真正在Azur ...

  8. Scala学习笔记(二)表达式和函数

    笔记的整理主要针对Scala对比Java的新特性:   1.if表达式 if表达式是有结果返回的. val a= if (5>2) "你好" else 1 a的值为if表达式 ...

  9. Mac IDEA快捷键积累

    切来切去:Ctrl+Tab 在打开的不同类中切换来切换去 完美代码结构:Alt+Command+L 不同编辑点跳转:Alt+Command+↔️ 快速重写:Ctrl+N 快速选择代码:Alt+Shif ...

  10. CSS 中常用的选择器(选择符)

    一.标签选择器:直接将HTML标签(Tag)作为选择器,可以是p.h1.dl.strong等HTML标签.如: p { font:12px;}em { color:blue;}dl { float:l ...