1. ホーム
  2. ios

NSUserDefaultsにカスタムオブジェクトを保存する [重複] [重複

2023-10-02 22:15:10

質問

お知らせがあります ViewControllerTeamViewController . は TeamViewController には teamObjects の tableView が含まれており、選択されると配列に追加されます。この配列を NSUserDefaults からアクセスできるように NewsController からアクセスすることができます。しかし、私は得ることを続ける。

'非プロパティリストオブジェクトを挿入しようとしました ( を挿入しようとしました。 ) をキー チームに挿入しようとしました'

に格納するよりも良い方法があれば、他の提案も受け付けます。 NSUserDefaults

didSelectRowAtIndexPath メソッド

override func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {
    tableView.deselectRowAtIndexPath(indexPath, animated: true)


    let team = self.teamArray[indexPath.row] as Team
    var removed = false

    for (index, value) in enumerate(self.teamSelected) {
        if (value == team) {
            self.teamSelected.removeAtIndex(index)
            removed = true
        }
    }

    if (!removed) {
        self.teamSelected.append(team)
    }

    var userDefaults = NSUserDefaults.standardUserDefaults()
    userDefaults.setValue(self.teamSelected, forKey: "teams")
    userDefaults.synchronize()

    tableView.reloadData()
}

私のオブジェクト

class Team: NSObject{
    var id: Int!
    var name: NSString!
    var shortname: NSString!


    init(id: Int, name:NSString, shortname: NSString) {
        self.id = id
        self.name = name
        self.shortname = shortname

    }

}

どのように解決するのですか?

実際には、カスタムオブジェクトを NSData にアーカイブし、それをユーザーデフォルトに保存し、ユーザーデフォルトからそれを取り出して再びアーカイブを解除する必要があります。 このようにアーカイブすることができます。

let teams = [Team(id: 1, name: "team1", shortname: "t1"), Team(id: 2, name: "team2", shortname: "t2")]

var userDefaults = UserDefaults.standard
let encodedData: Data = NSKeyedArchiver.archivedData(withRootObject: teams)
userDefaults.set(encodedData, forKey: "teams")
userDefaults.synchronize()

というようにアーカイブを解除します。

let decoded  = userDefaults.data(forKey: "teams")
let decodedTeams = NSKeyedUnarchiver.unarchiveObject(with: decoded) as! [Team]

しかし、これをそのまま実行すると

.Team encodeWithCoder:]: unrecognized selector sent to instance

このようにTeamをNSCodingに準拠させる必要があります。

class Team: NSObject, NSCoding {
    var id: Int
    var name: String
    var shortname: String


    init(id: Int, name: String, shortname: String) {
        self.id = id
        self.name = name
        self.shortname = shortname

    }

    required convenience init(coder aDecoder: NSCoder) {
        let id = aDecoder.decodeInteger(forKey: "id")
        let name = aDecoder.decodeObject(forKey: "name") as! String
        let shortname = aDecoder.decodeObject(forKey: "shortname") as! String
        self.init(id: id, name: name, shortname: shortname)
    }

    func encode(with aCoder: NSCoder) {
        aCoder.encode(id, forKey: "id")
        aCoder.encode(name, forKey: "name")
        aCoder.encode(shortname, forKey: "shortname")
    }
}