WedX - журнал о программировании и компьютерных науках

Как создавать представления в SwiftUI с помощью collect

Я пытаюсь найти способ вставить несколько массивов представлений в VStack в SwiftUI с помощью оператора collect().

struct ChatsTab: View {
    var subscriptions = Set<AnyCancellable>()
    var body: some View {
        VStack {
            ["A", "B", "C", "D", "E"].publisher.collect(2).sink(receiveCompletion: { _ in
                // Do nothing on completion
            }) { (stringArray) in
                HStack {
                    Text(stringArray[0])
                    Text(stringArray[1])
                }
            }
        .store(in: &subscriptions)
        }
    }
}

Но я получаю следующее сообщение об ошибке:

Cannot convert value of type '()' to closure result type '_'

Я хочу сделать это с collect только для того, чтобы добавить свои текстовые представления в пару. Я знаю, что у меня есть другие варианты, но я хочу сделать это только с collect.


Ответы:


1

Вам просто нужно все переставить. Настоящая проблема не в collect, проблема в том, что вы пытаетесь выполнить произвольный код внутри VStack. VStack - это конструктор функций, и между его фигурными скобками идет список представлений и, возможно, только некоторая базовая if логика. Не произвольный код, как тот, который вы включаете в обычную функцию. Поэтому, если вы извлечете код издателя из VStack, он будет скомпилирован. Где вы его разместите, зависит от вас, вы можете разместить его в init(), вызываемом из другой функции, или в модификаторе представления int didAppear (только не внутри VStack напрямую).

Вторая проблема заключается в том, что сбор опубликует другой массив (один длиной 2). По сути, вы получите массив массивов String (или вы можете просто использовать их по мере публикации, а не хранить их, в зависимости от того, что вы пытаетесь сделать). Вы также можете использовать более простую версию sink, поскольку Error издателя здесь Never. В любом случае, вот что-то, что включает вышеупомянутые изменения:


import SwiftUI
import Combine

var subscriptions = Set<AnyCancellable>()

struct ContentView: View {

  @State var stringArrays: [[String]] = []

    var body: some View {
      ForEach(stringArrays, id: \.self) { stringArray in
        HStack {
          Text(stringArray.count > 0 ? stringArray[0] : "")
          Text(stringArray.count > 1 ? stringArray[1] : "")
        }
      }.onAppear() {
        ["A", "B", "C", "D", "E"].publisher
          .collect(2)
          .sink(receiveValue: { (stringArray) in
            self.stringArrays.append(stringArray)
          }).store(in: &subscriptions)
      }
  }

}
23.01.2020
  • Это можно упростить еще больше, без сброса, используя assign: to, я думаю 23.01.2020
  • Вы можете использовать assign, но поскольку здесь я добавляю, а не перезаписываю, вам потребуется второй сбор перед повторным назначением, например .collect().assign(to: \ContentView.stringArrays, on: self). Также, глядя на мой пример, это не так ясно, как могло бы быть. Следует помнить, что все это ForEach представление, включая модификатор onAppear, является одним представлением. Произвольный код может быть в onAppear, потому что его аргумент является закрытием. 23.01.2020
  • Новые материалы

    Как создать диаграмму градиентной кисти с помощью D3.js
    Резюме: Из этого туториала Вы узнаете, как добавить градиентную кисть к диаграмме с областями в D3.js. Мы добавим градиент к значениям SVG и применим градиент в качестве заливки к диаграмме с..

    Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что это выглядит сложно…
    Просто начните и учитесь самостоятельно Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что он кажется мне сложным, и я бросил его. Это в основном инструмент..

    Лицензии с открытым исходным кодом: руководство для разработчиков и создателей
    В динамичном мире разработки программного обеспечения открытый исходный код стал мощной парадигмой, способствующей сотрудничеству, инновациям и прогрессу, движимому сообществом. В основе..

    Объяснение документов 02: BERT
    BERT представил двухступенчатую структуру обучения: предварительное обучение и тонкая настройка. Во время предварительного обучения модель обучается на неразмеченных данных с помощью..

    Как проанализировать работу вашего классификатора?
    Не всегда просто знать, какие показатели использовать С развитием глубокого обучения все больше и больше людей учатся обучать свой первый классификатор. Но как только вы закончите..

    Работа с цепями Маркова, часть 4 (Машинное обучение)
    Нелинейные цепи Маркова с агрегатором и их приложения (arXiv) Автор : Бар Лайт Аннотация: Изучаются свойства подкласса случайных процессов, называемых дискретными нелинейными цепями Маркова..

    Crazy Laravel Livewire упростил мне создание электронной коммерции (панель администратора и API) [Часть 3]
    Как вы сегодня, ребята? В этой части мы создадим CRUD для данных о продукте. Думаю, в этой части я не буду слишком много делиться теорией, но чаще буду делиться своим кодом. Потому что..


    Для любых предложений по сайту: [email protected]