Store [String] in NSUserDefaults

淺唱寂寞╮ 提交于 2019-11-26 20:23:02

The following code should help you resolve your problem:

import UIKit

class ViewController: UIViewController {

    var food: [String] {
        get {
            if let returnValue = NSUserDefaults.standardUserDefaults().objectForKey("food") as? [String] {
                return returnValue
            } else {
                return ["muesli", "banana"] //Default value
            }
        }
        set {
            NSUserDefaults.standardUserDefaults().setObject(newValue, forKey: "food")
            NSUserDefaults.standardUserDefaults().synchronize()
        }
    }

    override func viewDidLoad() {
        super.viewDidLoad()

        print(food) // prints: ["muesli", "banana"] (at first launch)

        food = ["cake"]
        print(food) // prints: ["cake"]

        food += ["spaghetti"]
        print(food) // prints: ["cake", "spaghetti"]

        food = []
        print(food) // prints: []

        NSUserDefaults.standardUserDefaults().setObject(nil, forKey: "food")
        print(food) // prints: ["muesli", "banana"]
    }

}

However, with the previous code, if you set food = [], you will have a problem as food won't return ["muesli", "banana"]. In order to avoid this, you may prefer the following code:

import UIKit

class ViewController: UIViewController {

    var food: [String] {
        get {
            if let returnValue = NSUserDefaults.standardUserDefaults().objectForKey("food") as? [String] {
                return returnValue == [] ? ["muesli", "banana"] : returnValue
            } else {
                return ["muesli", "banana"] //Default value
            }
        }
        set {
            NSUserDefaults.standardUserDefaults().setObject(newValue, forKey: "food")
            NSUserDefaults.standardUserDefaults().synchronize()
        }
    }

    override func viewDidLoad() {
        super.viewDidLoad()

        print(food) // prints: ["muesli", "banana"] (at first launch)

        food = ["cake"]
        print(food) // prints: ["cake"]

        food += ["spaghetti"]
        print(food) // prints: ["cake", "spaghetti"]

        food = []
        print(food) // prints: ["muesli", "banana"]

        NSUserDefaults.standardUserDefaults().setObject(nil, forKey: "food")
        print(food) // prints: ["muesli", "banana"]
    }

}

As stated in the documentation:

For NSArray and NSDictionary objects, their contents must be property list objects.

This means you need to convert your String objects to NSString when saving, something like this should work:

var food : [String] {
    get {
        var returnValue : [String]? = NSUserDefaults.standardUserDefaults().objectForKey("food") as? [String]
        if returnValue == nil      //Check for first run of app
        {
            returnValue = ["muesli", "banana"]; //Default value
        }
        return returnValue!
    }
    set (newValue) {
        //  Each item in newValue is now a NSString
        let val = newValue as [NSString]
        NSUserDefaults.standardUserDefaults().setObject(val, forKey: "food")
        NSUserDefaults.standardUserDefaults().synchronize()
    }
}

In Swift 3.0

Store

UserDefaults.standard.set(newValue, forKey: "yourkey")
UserDefaults.standard.synchronize()

Retrieve

var returnValue: [NSString]? = UserDefaults.standard.object(forKey: "yourkey") as? [NSString]

Remove

UserDefaults.standard.removeObject(forKey: "yourkey")

Reference: NSUserdefault objectTypes

Set and Get NSUserDefault with function

Use below function to globally use , declare in any class any use in whole app

Declaration

func setUserDefault(ObjectToSave : AnyObject?  , KeyToSave : String)
{
    let defaults = NSUserDefaults.standardUserDefaults()

    if (ObjectToSave != nil)
    {

        defaults.setObject(ObjectToSave, forKey: KeyToSave)
    }

    NSUserDefaults.standardUserDefaults().synchronize()
}

func getUserDefault(KeyToReturnValye : String) -> AnyObject?
{
    let defaults = NSUserDefaults.standardUserDefaults()

    if let name = defaults.valueForKey(KeyToReturnValye)
    {
        return name
    }
    return nil
}

How to call

Classname_where_this_function_declare.sharedInstance.setUserDefault("value", KeyToSave: "key")**  
Nikunj Patel

//

    class func saveCustomObject(_ object: AnyObject?, key: String) { 
      let encodedObject = NSKeyedArchiver.archivedData(withRootObject: object!) 
      let userDefaults = UserDefaults.standard userDefaults.set(encodedObject, forKey: key) 
      userDefaults.synchronize() 
    } 

//

class func loadCustomObject(_ key: String) -> AnyObject? { 
   let userDefaults = UserDefaults.standard 
   if let userDefaultKey = userDefaults.object(forKey: key) { 
     let encodedObject = userDefaultKey as! NSData 
     return NSKeyedUnarchiver.unarchiveObject(with: encodedObject as Data)! as AnyObject? 
   } else {
     return nil 
   }
} 

//

class func removeCustomObject(_ key: String) { // 
    let encodedObject = NSKeyedArchiver.archivedDataWithRootObject(object!) let userDefaults = 
    UserDefaults.standard userDefaults.removeObject(forKey: key) 
    userDefaults.synchronize()
 }

call Method

let aParams : [String : String] = [ "DeviceType" : "iOS", ]
CommonMethods.saveCustomObject(aParams as AnyObject?, key:Constants.kLoginData)

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!