Snowfun

导航

 

在iOS下编写TableView是很容易的。

最简单的TableView

比如实现这样的效果:

image

首先创建一个view based application:

image

接着,修改view xib文件,将TableView拖拽到view中:

image image

右侧图是拖拽后的效果。然后是建立关联,需要建立两个:

  • dataSource,连接到数据源,这样TableView才知道显示数据的信息
  • delegate,连接到TableView delegate,回调它来和应用的逻辑部分交互

都连接到Controller即可,即file’s owner:

image

然后,需要让Controller实现两个protocol:

@interface TableDemoViewController : UIViewController<UITableViewDelegate,UITableViewDataSource>

其中UITableViewDataSource要求两个方法必须实现:

image

这里要先在h文件中声明用于dataSource的数据结构,这是使用的是固定数组:

    NSArray *dataItems;
}

@property(nonatomic,retain) NSArray *dataItems;

 

然后,在m文件中实例化数组:

@synthesize dataItems;

- (void)viewDidLoad {
    dataItems= [[NSArray alloc] initWithObjects:@"张三",@"李四",nil];
    [super viewDidLoad];
}

现在可以实现上面的两个方法了:

-(NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section{
    return [dataItems count];
}

-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{
    static NSString *simpleTableIdentifier=@"SimpleTableIdentifier";
    UITableViewCell *cell=[tableView dequeueReusableCellWithIdentifier:simpleTableIdentifier];
    if(cell==nil){
        cell=[[[UITableViewCell alloc] initWithFrame:CGRectZero reuseIdentifier:simpleTableIdentifier] autorelease];
    }
    NSUInteger row=[indexPath row];
    cell.textLabel.text=[dataItems objectAtIndex:row];
    return cell;
}

这里要注意,我写的例子是参照《iPhone开发基础教程》,里面的写法是:

cell.text=…

已经不建议使用了:

image

在TableView条目前添加图片

如果想实现这样的效果:

image

这里的图片,来自项目自身,可以将图片拖拽到项目的Resources目录下:

image

然后在代码中只需增加一行:

-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{
    static NSString *simpleTableIdentifier=@"SimpleTableIdentifier";
    UITableViewCell *cell=[tableView dequeueReusableCellWithIdentifier:simpleTableIdentifier];
    if(cell==nil){
        cell=[[[UITableViewCell alloc] initWithFrame:CGRectZero reuseIdentifier:simpleTableIdentifier] autorelease];
    }
    NSUInteger row=[indexPath row];
    cell.textLabel.text=[dataItems objectAtIndex:row];
    cell.imageView.image=[UIImage imageNamed:@"tag.png"];
    return cell;

 

为TableView增加交互功能

只需增加一个函数即可,这是UITableViewDelegate protocol中的一个函数,用于在选择表条目后回调。

-(void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath{
    NSLog(@">>choose:%@",[dataItems objectAtIndex:[indexPath row]]);
}

这样当点击条目后,日志中就会打印条目中的数据。

http://marshal.easymorse.com/archives/3511
posted on 2011-05-14 16:07  Snowfun  阅读(1126)  评论(0编辑  收藏  举报