1

我正在开发一个列表应用程序,我有一些针对一种特定数据类型的添加/删除/编辑/加载功能,但是我想概括这些功能,所以我可以从内部对任何数据类型执行相同的操作任何观点。

我已经设置了一个全局变量类:

import SwiftUI
import CoreData

class GlobalVariableClass: ObservableObject {
   @Published var itemObjects: [NSManagedObject] =  []
}

在 SceneDelegate 中放置了一个类的实例

class SceneDelegate: UIResponder, UIWindowSceneDelegate {

   var globalVariables = GlobalVariableClass()

   ...

将实例传递给 contentView

let contentView = Home()
         .environmentObject(globalVariables)
         .environment(\.managedObjectContext, context)

现在,当我@EnvironmentObject var globalVariables: GlobalVariableClass在任何视图中声明时,我可以访问itemObjects,它将所有输入的项目存储到一个文本字段中。

这很好,但我正在尝试使用不在视图中的全局函数。

我在全局级别的单独文件中声明它们,以便它们具有公共访问权限。

确切的问题在do块内下面。

func loadItems() {

   guard let appDelegate =
      UIApplication.shared.delegate as? AppDelegate else {
         return
   }

   let managedContext =
      appDelegate.persistentContainer.viewContext

   let fetchRequest =
      NSFetchRequest<NSManagedObject>(entityName: "Item")

   do {
      GlobalVariableClass().itemObjects = try managedContext.fetch(fetchRequest)
   }   catch let error as NSError {
      print("Could not fetch. \(error), \(error.userInfo)")
   }
}

访问 itemObjectsGlobalVariableClass().itemObjects 结果在我的应用程序中没有加载任何内容。

虽然如果我在 listItem 视图中声明加载函数,声明环境对象globalVariables,然后将其更改为

do {
      globalVariables.itemObjects = try managedContext.fetch(fetchRequest)
   }

然后一切都加载得很好。

关于如何从全局函数中访问 itemObjects 的任何建议?

4

1 回答 1

3

可能的方法是使用共享实例,例如

class GlobalVariableClass: ObservableObject {
   static var shared = GlobalVariableClass()     // << here !!

   @Published var itemObjects: [NSManagedObject] =  []
}

所以你可以使用它

class SceneDelegate: UIResponder, UIWindowSceneDelegate {

   var globalVariables = GlobalVariableClass.shared

   do {
      let results = try managedContext.fetch(fetchRequest)

      // make sure to modify itemObjects always in main queue
      DispatchQueue.main.async {    // << must !!
         GlobalVariableClass.shared.itemObjects = results
      }
   }   catch let error as NSError {
      print("Could not fetch. \(error), \(error.userInfo)")
   }
于 2020-05-12T03:40:07.770 回答