U
25 серпня 2020 р. 16:04

JSONListModel + qml изменения в модели

qml

Использую в проекте JSONListModel (https://wiki.qt.io/JSONListModel)

JSONListModel{
        id: tab1Info
    }

Заполняю ее:

string tmpStr = "[{\"name\": \"n1\"}, {\"name\": \"n2\"}]"
tab1Info.json = tmpStr

Затем при нажатии на кнопку - добавляю еще один объект в модель

tab1Info.model.append({"name": "n3"})

При этой манипуляции - в ListView, которому моделью приходится моя tab1Info, отображается всё хорошо: там добавляется еще одна строчка, которая и показывает, что в модель был добавлен объект...

Но потом мне нужно получить описание модифицированной модели... Те я хочу получить:
[{"name":"n1"},{"name":"n2"},{"name":"n3"}]

Но никак не получается получить... Пытаюсь вывести в консоль:

console.log(tab1Info.json)

Возвращает: [{"name":"n1"},{"name":"n2"}]
Те получается, что модель-то изменилась, но .json остался прежним...
Как вернуть описание модифицированной модели, подскажите плиз?

1

Вам це подобається? Поділіться в соціальних мережах!

3
Evgenii Legotckoi
  • 25 серпня 2020 р. 16:25

Вы взяли исходники этой модели с GitHub? Там в принципе не предусмотрен функционал по формированию готового json из модели.
Фактически данная модель годится только для чтения JSON, чтобы отобразить в табличке.
Вам нужно изначально манипулировать json текстом, а ту модель по-хорошему разработчику нужно было сделать read only.
Это скорее какой-то прототип был, который написали 8 лет назад и забыли.

    U
    • 25 серпня 2020 р. 16:31

    Спасибо)
    Хоть я и подавлен))) Но все равно спасибо)

      Evgenii Legotckoi
      • 25 серпня 2020 р. 16:35

      Да не за что. Там нужно дописывать исходник той модели так, чтобы при изменении внутренней модели обновлялся сам JSON.
      Но видимо это будет немного посложнее, поэтому разработчик благополучно слился.
      Впрочем, если каждая строка просто показывает содержимое каждой строки развёрнутого JSON, то возможно, при проходе в цикле, можно заново сформировать текст json из элементов модели, но только, если там будет вся необходимая информация о скобках и запятых.

        Коментарі

        Only authorized users can post comments.
        Please, Log in or Sign up