Как построить список динамических строк в Flutter?

Я пишу приложение / игру, в которой пользователь вводит свои собственные правила для текстовых полей, хранящихся в базе данных SQFLite.

Правила связаны с другом, поэтому он находится в классе Friend с идентификатором, именем, rule0, rule1, rule2...rule9. Который ДЕЙСТВИТЕЛЬНО раздражает по многим причинам, но я думаю, мне нужно, чтобы он был в классе Friend, чтобы он хранился с нужным friend.id.

Я получил очевидную ошибку "только статические члены могут быть доступны на инициализаторах", когда я пытаюсь List<Strings> rules = [rule0, rule1]; или же List<dynamic> rules = [...];

Кто-нибудь знает, как я мог это исправить? Создать новый класс Rules, и у каждого правила есть идентификатор, связанный с нужным другом? Или, если я могу просто создать динамический список в Friend?

Действительно потерял на этом. Любая помощь приветствуется.

class Friend {

  int id;
  String name;
  String pic;
  bool play;
  String rule0;
  String rule1;
  String rule2;
  String rule3;
  String rule4;
  String rule5;
  String rule6;
  String rule7;
  String rule8;
  String rule9;

  Friend();

  // i have then a fromMap() and a toMap() for the database

}

1 ответ

Решение

Я не совсем уверен, но кажется, что у вас проблемы как с аспектом SQL, так и с представлением классов ваших данных.

Если вы точно знаете, что будет только определенное количество правил, вы можете подойти к нему так же, как в настоящее время. В дополнение я бы сделал функцию 'getter' для списка правил, т.е.

List<String> get rules => [rule1, rule2, rule2, ...].where((item) => item != null).toList()

Обратите внимание, что если бы вы использовали конструктор, вы могли бы вместо этого построить список в конструкторе следующим образом:

class Friend {
  int id;
  String name;
  String pic;
  bool play;
  String rule0;
  String rule1;
  String rule2;
  String rule3;
  String rule4;
  String rule5;
  String rule6;
  String rule7;
  String rule8;
  String rule9;

  List<String> rules;

  Friend(
      {this.id,
      this.name,
      this.pic,
      this.play,
      this.rule0,
      this.rule1,
      this.rule2,
      this.rule3,
      this.rule4,
      this.rule5,
      this.rule6,
      this.rule7,
      this.rule8,
      this.rule9})
      : rules = [
          rule0,
          rule1,
          rule2,
          rule3,
          rule4,
          rule5,
          rule6,
          rule7,
          rule8,
          rule9,
        ].where((item) => item != null).toList(growable: false);
}

Хотя я бы не рекомендовал это делать (или, если вы это сделаете, вам, вероятно, следует сделать либо правило *, либо правила частным, либо каким-либо образом поддерживать состояние). В списке строк хранятся ссылки не на строки rule0, rule1, ..., а на сами строки. Вы можете обойти это, сделав класс Rule и сделав final0-9 окончательным, но это становится немного сложнее.


Скорее всего, имеет смысл иметь динамический список элементов. SQL не справляется с этим, поэтому вам придется создать отдельную таблицу для правил.

У вас будет две таблицы примерно так, где id оба первичные ключи и friendId ИНОСТРАННЫЙ КЛЮЧ:

Friend(id, name, pic, play) а также Rule(id, friendId, text)

Сохранение и обновление станут более сложными. Вы должны быть более осторожны с ведением списка правил в базе данных, но это не так уж сложно. Если вы знаете, что будете писать в список только из одного места (то есть из одного класса), вы можете сохранить разницу между текущим состоянием класса и начальным состоянием, но реально, если вы не имеете дело с десятками тысяч правил, это, вероятно, не будет иметь значительного значения.

Другие вопросы по тегам