Обновление списка SwiftUI
Я пытаюсь обновить этот список всякий раз, когда я нажимаю на NavLink
NavigationView {
List(feed.items.indices, id:\.self) { i in
NavigationLink(destination: ListFeedItemDetail(idx: i).environmentObject(self.feed)) {
ListFeedItem(item: self.$feed.items[i])
}
}
}
Список состоит из массива внутри объекта среды. Проблема: он обновляется только тогда, когда я переключаюсь на другую вкладку или закрываю приложение, в котором я использовал модальное представление ранее, и это сработало там. (Я сделал это с.onAppear) Есть идеи?
пример
Проблема: Когда вы нажимаете на элемент в списке и нажимаете кнопку переключения, объект EnvironmentObject изменяется, но это изменение отражается только при изменении вкладки и ее изменении снова
import SwiftUI
import Combine
struct TestView: View {
@State var showSheet: Bool = false
@EnvironmentObject var feed: TestObject
func addObjects() {
var strings = ["one","two","three","four","five","six"]
for s in strings {
var testItem = TestItem(text: s)
self.feed.items.append(testItem)
}
}
var body: some View {
TabView {
NavigationView {
List(feed.items.indices, id:\.self) { i in
NavigationLink(destination: detailView(feed: self._feed, i: i)) {
HStack {
Text(self.feed.items[i].text)
Text("(\(self.feed.items[i].read.description))")
}
}
}
}
.tabItem({ Text("Test") })
.tag(0)
Text("Blank")
.tabItem({ Text("Test") })
.tag(0)
}.onAppear {
self.addObjects()
}
}
}
struct detailView: View {
@EnvironmentObject var feed: TestObject
var i: Int
var body: some View {
VStack {
Text(feed.items[i].text)
Text(feed.items[i].read.description)
Button(action: { self.feed.items[self.i].isRead.toggle() }) {
Text("Toggle read")
}
}
}
}
final class TestItem: ObservableObject {
init(text: String) {
self.text = text
self.isRead = false
}
static func == (lhs: TestItem, rhs: TestItem) -> Bool {
lhs.text < rhs.text
}
var text: String
var isRead: Bool
let willChange = PassthroughSubject<TestItem, Never>()
var read: Bool {
set {
self.isRead = newValue
}
get {
self.isRead
}
}
}
class TestObject: ObservableObject {
var willChange = PassthroughSubject<TestObject, Never>()
@Published var items: [TestItem] = [] {
didSet {
willChange.send(self)
}
}
}
1 ответ
У меня была похожая проблема, это хак, который я придумал.
В вашем "TestView" объявите:
@State var needRefresh: Bool = false
Передайте это вашему месту назначения detailView, например:
NavigationLink(destination: detailView(feed: self._feed, i: i, needRefresh: self.$needRefresh)) {
HStack {
Text(self.feed.items[i].text)
Text("(\(self.feed.items[i].read.description))")
}.accentColor(self.needRefresh ? .white : .black)
}
Обратите внимание на ".accentColor(self.needRefresh? .White: .black)" для принудительного обновления при изменении "needRefresh".
В пункт назначения "detailView" добавьте:
@Binding var needRefresh: Bool
Затем в вашем "detailView" в вашем действии Button добавьте:
self.needRefresh.toggle()