- 一步一步熟悉Mac app开发(四)之ArrayControll
- 一步一步熟悉Mac app开发(二)之NSCollectionV
- 一步一步熟悉Mac app开发(三)之NSTableView
- 一步一步熟悉Mac app开发(七)之NSAlert
- 一步一步熟悉Mac app开发(九)之NSPopover
- 一步一步熟悉Mac app开发(一)之containerView
- 一步一步熟悉Mac app开发(六)之NSOutlineView
- 一步一步熟悉Mac app开发(八)之NSNotificatio
- 一步一步熟悉Mac app开发(十一)之Radio Button
- 一步一步熟悉Mac app开发(十)之Cocoa Binding
概要
本文分为两个阶段。
阶段一,实现数据的增、删。
阶段二,实现数据的绑定,对绑定的数据增、删。
阶段一
1.新建项目。
data:image/s3,"s3://crabby-images/23d8a/23d8a795ad7fe9af2567084101df8a6e39b74f19" alt=""
2.删除不必要的标签。
data:image/s3,"s3://crabby-images/83ddd/83ddda6ce4202b725dcfae6859dd7bdc78800f32" alt=""
3.添加array controller至默认的view controller中。
data:image/s3,"s3://crabby-images/1297f/1297f2dad745679f78a8a747e4490ca3f7e6914e" alt=""
4.创建一个NSObject的子类,命名为Song,添加两个属性,并设置其初始化方法。(不会的,请参考上篇文章。)
//Song.h
#import <Foundation/Foundation.h>
@interface Song : NSObject
@property NSString *name;
@property NSInteger bpm;
@end
//Song.m
#import "Song.h"
@implementation Song
- (id) init{
self = [super init];
if(self){
_name = @"New Song";
_bpm = 100;
}
return self;
}
@end
5.在Document.h中添加songs成员,并在Document.m中对songs进行初始化。
//Document.m(节约内存/流量,仅放核心代码)
#import "Song.h"
@interface Document ()
@property NSMutableArray *songs;
@end
- (instancetype)init {
self = [super init];
if (self) {
// Add your subclass-specific initialization here.
_songs =[[NSMutableArray alloc] initWithCapacity:64];
[_songs addObject:[Song new]];
}
return self;
}
6.回到storyboard,添加object至默认的view controller中,并且设置其Custom Class为“Document”。
data:image/s3,"s3://crabby-images/f8a8e/f8a8e19d9106199c2737786f559605f220468b4d" alt=""
data:image/s3,"s3://crabby-images/b2291/b2291b6b06f8774718d7c8f71897e2b62b30d759" alt=""
7.设置array controller的设置ArrayController的【Object Controller】中【Class Name】为Song,然后设置【Content Array】绑定为Docuemnt,并且设置其【Model Key Path】为songs。
data:image/s3,"s3://crabby-images/e435b/e435b2359410f34389eaeb0b2b2f03061bf71355" alt=""
data:image/s3,"s3://crabby-images/d77dd/d77dd86019f254913cca6c66d138e51211f2c94c" alt=""
8.添加一个TableView和两个按钮,布局如下。
data:image/s3,"s3://crabby-images/b805d/b805daeccf64c1d73b7697a683306e340d5d917c" alt=""
9.将TableView绑定于Array Controller。
data:image/s3,"s3://crabby-images/14c21/14c21a70e46b90ebda5d24bab8699967f45d34ff" alt=""
10.将两个按钮与Array Controller的add和reomve方法绑定起来。
data:image/s3,"s3://crabby-images/22305/223059864983d7052eb99fcc232b237882c8258a" alt=""
11.阶段一完成,效果如下。
data:image/s3,"s3://crabby-images/c28d4/c28d4e2d580201bc6c3824383d86ab26cf2100ba" alt=""
阶段二 绑定数据
1.绑定第一列、第二列到name和bpm属性上。
data:image/s3,"s3://crabby-images/15cbf/15cbfda232ea3f69f1880efcc87d8f5d7f82e96b" alt=""
data:image/s3,"s3://crabby-images/d6ab5/d6ab5b1cd77ff093f44c1f38d155c81e6fdde9c9" alt=""
2.完成,效果如下。
data:image/s3,"s3://crabby-images/20239/202394bce216054574801e05756624051363ea26" alt=""
复习
可以根据以下项目来复习使用ArrayController。
一步一步熟悉Mac app开发(十)之Cocoa Binding
网友评论