Ich habe eine Tabelle, die auf folgende Weise funktioniert. Wenn eine Zeile ausgewählt ist, wird ein der ausgewählten Zeile entsprechender Wert zu var total
hinzugefügt, ein Häkchen wird hinzugefügt. Wenn es deaktiviert ist, wird der Betrag abgezogen, das Häkchen wird auf "Keine" gesetzt. Mein Code funktionierte ordnungsgemäß, bevor versucht wurde, die Daten zu/von NSUserDefaults zu speichern/abzurufen. Die Fehler sind: Wenn ich die erste Zeile auswähle, subtrahiert sie den Betrag, anstatt ihn hinzuzufügen; Nachdem eine Zeile ausgewählt wurde, wenn ich auf die Zurück-Schaltfläche klicke und dann zum selben Bildschirm zurückkehre, wird das Häkchen nicht angezeigt. In diesem Konstrukt, wenn ich versuche, von NSUserDefaults abrufen indexPathForCellSelected
wertet auf Null, obwohl ich if indexPathForCellSelected != nil
überprüfen, bevor die Zuordnung zu machen. fataler Fehler: unerwartet null gefunden, während ein optionaler WertFehler beim Speichern in NSUserdefaults
if indexPathForCellSelected != nil { self.tableView.cellForRowAtIndexPath(indexPathForCellSelected!)?.
accessoryType = .Checkmark
}
class NinethViewController: UIViewController, UITableViewDelegate,UITableViewDataSource {
var total = 0
var indexRowRetrieved:Int?
var rowSelected:Int?
var indexRowSelectedKey = "indexRowKey"
var amountKey = "amountKey"
var totalKey = "totalKey"
let indexPathKey = "indexPathForCellSelected"
var indexPathForCellSelected: NSIndexPath?
struct Item {
var name:String // name of the row
var selected:Bool // whether is selected or not
var amount: Int // value of the item
}
var extras = [
Item(name:"Inside Cabinets",selected: false, amount: 5),
Item(name:"Inside Fridge",selected: false, amount: 5),
Item(name:"Inside Oven",selected: false, amount: 5),
Item(name:"Laundry wash & dry",selected: false, amount: 10),
Item(name:"Interior Windows", selected: false, amount: 5)
]
@IBOutlet weak var tableView: UITableView!
override func viewDidLoad() {
super.viewDidLoad()
}
override func viewDidAppear(animated: Bool) {
super.viewDidAppear(animated)
// loadData from NSUserDefaults
loadData()
}
func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return extras.count
}
func numberOfSectionsInTableView(tableView: UITableView) -> Int {
return 1
}
// configure the cell
func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath)
-> UITableViewCell {
let cell = tableView.dequeueReusableCellWithIdentifier("Cell")
cell?.textLabel?.text = extras[indexPath.row].name
return cell!
}
func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {
// if the cell has not been selected before
if !extras[indexPath.row].selected {
// marks the cell as selected
extras[indexPath.row].selected = true
tableView.cellForRowAtIndexPath(indexPath)?.accessoryType = .Checkmark
self.total += extras[indexPath.row].amount
indexPathForCellSelected = indexPath
rowSelected = indexPath.row
print(total)
// save all info in NSUserDefaults
saveData()
} else {
// marks the cell as not selected
extras[indexPath.row].selected = false
tableView.cellForRowAtIndexPath(indexPath)?.accessoryType = .None
self.total -= extras[indexPath.row].amount
print(total)
}
}
func saveData(){
// save indexPathForCellSelected in NSUserDefaults
if indexPathForCellSelected != nil {
let data = NSKeyedArchiver.archivedDataWithRootObject(indexPathForCellSelected!)
NSUserDefaults.standardUserDefaults().setObject(data, forKey: indexPathKey)
// save indexRowSelected
NSUserDefaults.standardUserDefaults().setInteger(rowSelected!, forKey: indexRowSelectedKey)
// save amount for corresponding row in NSUserDefaults
NSUserDefaults.standardUserDefaults().setObject(extras[rowSelected!].amount, forKey: amountKey)
//save total in NSUserDefaults
NSUserDefaults.standardUserDefaults().setObject(total, forKey: totalKey)
}
}
func loadData() {
//retrieve indexPathForCellSelected from NSUserDefaults
if let retrievedIndexPath = NSUserDefaults.standardUserDefaults().dataForKey(indexPathKey) {
if let data1 = NSKeyedUnarchiver.unarchiveObjectWithData(retrievedIndexPath) as? NSIndexPath{
indexPathForCellSelected = data1
}
}
// retrieve the index for row selected to select the state of the row: true or false
if let retrievedIndexRow = NSUserDefaults.standardUserDefaults().integerForKey(indexRowSelectedKey) as? Int {
indexRowRetrieved = retrievedIndexRow
extras[retrievedIndexRow].selected = true
}
// retrieve amount for corresponding row in NSUserDefaults
if let itemAmount = NSUserDefaults.standardUserDefaults().objectForKey(amountKey) as? Int {
extras[indexRowRetrieved!].amount = itemAmount
// assign checkmark to row selected
if indexPathForCellSelected != nil {
self.tableView.cellForRowAtIndexPath(indexPathForCellSelected!)?.accessoryType = .Checkmark
}
}
// retrieve total from NSUserDefaults
if let totalRetrieved = NSUserDefaults.standardUserDefaults().objectForKey(totalKey) as? Int {
total = totalRetrieved
print(total)
}
}
}
Siehe meine Antwort, Entschuldigung für die Verzögerung. Ich war beschäftigt –