首页 > 解决方案 > 我应该如何获取和设置 UserDefaults 的值?

问题描述

我目前正在使用 SwiftUI 开发应用程序。

我想在这个应用程序中使用 UserDefaults 值。所以我在下面做了一个代码。

但在这种情况下,当我重新启动应用程序(以下过程中的第 4 个进程)时,我无法从 UserDefaults 中获得价值......

  1. 构建并运行这个项目。

  2. Pless 主页按钮和应用程序进入后台。

  3. 双击主页按钮并删除应用程序屏幕。

  4. 按应用程序图标并重新启动应用程序。然后我想从 UserDefaults 中获取价值。

在此处输入图像描述

要解决此问题,我应该如何在 UserDefaults 中设置和获取值?


这是代码:

import SwiftUI

struct ContentView: View {
    
    @State var text = "initialText"
    
    var body: some View {
        VStack {
            Text(text)
            TextField( "", text: $text)
        }.onAppear(){
            if let text = UserDefaults.standard.object(forKey: "text" ){
                self.text = text as! String
            }
        }
        .onDisappear(){
            UserDefaults.standard.set(self.text, forKey: "text")
        }
    }
}

struct ContentView_Previews: PreviewProvider {
    static var previews: some View {
        ContentView()
    }
}

添加

当我在第一个答案之后添加这个类时,该代码有几个像这样的错误,这通常吗?

在此处输入图像描述


Xcode:版本 11.7

斯威夫特:斯威夫特 5

标签: swiftuiswift5

解决方案


在这样的类中设置您的值:Bool、String(参见示例)、Int 等...

#if os(iOS)
import UIKit
#else
import AppKit
#endif

import Combine

@propertyWrapper struct UserDefault<T> {

   let key: String
   let defaultValue: T

   init(_ key: String, defaultValue: T) {
       self.key = key
       self.defaultValue = defaultValue
   }

   var wrappedValue: T {
       get {
           return UserDefaults.standard.object(forKey: key) as? T ?? defaultValue
       }
       set {
           UserDefaults.standard.set(newValue, forKey: key)
       }
   }
}

final class UserSettings: ObservableObject {

   let objectWillChange = PassthroughSubject<Void, Never>()

   @UserDefault("myText", defaultValue: "initialText")
   var myText: String {
       willSet { objectWillChange.send() }
   }

}

阅读:

let settings = UserSettings()
let count = settings.countSentence // default countsentence 1

这要更新:

let settings = UserSettings()
settings.countSentence = 3 // default countsentence 3

根据您的代码:

struct ContentView: View {

let UserDef = UserSettings()
@State var text = ""

var body: some View {
    VStack {
        Text(UserDef.myText)
        TextField("placeholder", text: $text, onCommit: { self.UserDef.myText = self.text})
    }.onAppear() {
        self.text = self.UserDef.myText
    }
}
}

推荐阅读