data:image/s3,"s3://crabby-images/37dd4/37dd404912758b9564a78719d67165218058738d" alt=""
This is without doubt the world's simplest NSTableView bindings example. To try it out, create a standard XCode Cocoa application and add the relevant items from this post to it.
The AppDelegate has an init method, which calls another function to load some preliminary data from a plist file. This has to happen before "awakeFromNib" or the TV won't display anything when it launches. I put the data in a plist file in resources for convenience, but you could easily construct it from scratch. I show the scratch version because the plist won't display properly in html:
If you wanted to load the data from a plist resource, you would do something like this instead:
The data variable is declared in the header as usual (no getters or setters or @property stuff):
The AppDelegate also has a method so I can see what has happened to the data source.
That's all the code there is! The window of the running application, again:
data:image/s3,"s3://crabby-images/37dd4/37dd404912758b9564a78719d67165218058738d" alt=""
In IB, drag an array controller onto the nib:
data:image/s3,"s3://crabby-images/747f4/747f4971a94cded84bdb4c17d70dbfc5af5f07da" alt=""
Here are the bindings. Be sure the table columns are selected when you bind to the array controller.
data:image/s3,"s3://crabby-images/b56bf/b56bffffd88ba06b42f36d99c1d18d4f32846971" alt=""
data:image/s3,"s3://crabby-images/c1e67/c1e67179f856764df74ec540cb54812960b36da0" alt=""
As shown in the screenshot, there is a Table View with two columns. Editing works, and the + and - buttons add new rows or delete the selected row. Connect the + and - buttons by control drag to the controller, and report to the App Delegate, as usual. Check the connections for the array controller.
data:image/s3,"s3://crabby-images/cb9f0/cb9f046dad023e31c4fd4f6c657ebe23fdbeffa1" alt=""
Make sure the array controller knows the right class to add to the array:
data:image/s3,"s3://crabby-images/53bb4/53bb408fed3385b5d3d97f5f2654827676cc0991" alt=""
One thing I don't know how to do yet is to change the default behavior, which only adds at the end, to add a new row after the selected row, say, at the second position. I suppose the way to do that is to connect the buttons to the App Delegate and modify the data source.