Privacy policyContactsAbout siteOpinionsGitHubDonate
© EVILEG 2015-2018
Recommend hosting
TIMEWEB
Oct. 31, 2018, 12:08 p.m.

Динамическая подмена моделей для ListView

Есть ListView для которого я меняю модели, которые заполняю из SqlLite. В принципе все работает, но кое-что непонятно.

Пример - при клике на текущей строке ListView у меня срабатывает следующая функция


 MouseArea {  
onClicked: { EsdDb.readDataSea_phones(parent_officeid);}
}

где

function readDataSea_phones(m_usersid) {
    seaPhones.clear();

    if(!db) { return; }

    db.transaction( function(tx) {
        var sql_text1='select surname, name, middle_name, name_rec, usersid, staffid, name_sokr, officeid, av_path from all_tel where usersid = '+'\'' +m_usersid +'\'';

        var result = tx.executeSql(sql_text1);
        for(var i = 0; i < 1; i++) {
            seaPhones.append({phone:result.rows.item(i).surname+" "+ result.rows.item(i).name+" "+result.rows.item(i).middle_name, tip_n:"" ,usersid: result.rows.item(i).usersid, av_path: result.rows.item(i).av_path});
        }
    } );

    db.transaction( function(tx) {
        var sql_text='select phone, tip_n, usersid from all_phones where usersid = '+'\'' +m_usersid +'\'';
        var result = tx.executeSql(sql_text);
        for(var i = 0; i < result.rows.length; i++) {
            seaPhones.append({phone:result.rows.item(i).phone, tip_n: result.rows.item(i).tip_n, usersid: result.rows.item(i).usersid, av_path: ""});
        }
    } );
    root_i.model_name="seaPhones";
    view_all_tree.model=seaPhones;

}



В этом скрипте я выполняю запрос к базе данных и подменяю текущую модель для ListView на другую. Все работает. Но я в консоле вижу, что QML сначала рефрешит старую модель, а уже затем отображает новую. У меня генерятся ошибки вывода на экран типа qrc:/content/TelSpr.qml:759 : ReferenceError: phone is not defined , и действительно - поле phone у меня описано в той модели, которую я присваиваю в скрипте, А не в той которая текущая была. Но скрипт то отработал. Я вижу по логам, что скрипт отработал, потом ошибки предыдущего отображения, потом нормальный вывод на экран той модели, которую я заполнил в скрипте.


данные модели я вывожу так


Text  {
                        id:text_tree
                        padding : 5
                        width: parent.width
                        renderType: Text.NativeRendering
                        font.pixelSize: dp(19);
                        font.bold: true
                        textFormat: Text.StyledText
                        wrapMode: "Wrap"

                        function model_field(field)
                        {
                            if(field ==='myModel_All_tree'){
                                return name_office
                            }
                            if(field ==='myModel_All_tel'){
                                return fio
                            }
                            if(field ==='myModel_All_phones'){
                                return phone
                            }
                            if(field ==='seaModel_id'){
                                return name_sokr+" "+name_rec
                            }
                            if(field ==='seaModel'){
                                return name_sokr+" "+name_rec
                            }
                            if(field ==='seaPhones'){
                                return phone+"   "+tip_n
                            }
                            if(field ==='seaTree'||field ==='seaTree_lvl_1'||field ==='seaTree_lvl_2'||field ==='seaTree_lvl_3'){
                                return name_office
                            }
                            else
                            {
                                return ""
                            }
                        }
                        text: model_field(root_i.model_name)
                    }
                }



То есть в зависимости от того какая модель - выводятся соотв. поля. Еще раз повторюсь - на вид все работает. Но мне не нравится то что происходит в логах.











4

Думаю, что проблема вот в этом.

root_i.model_name="seaPhones";

view_all_tree.model=seaPhones;

Вернее в местоположении этих строчек.

Сначала установите имя модели, а потом уже данные с полем phone начинайте добавлять. Скорее всего перерисовка выпонляется при каждом добавлении данных в таблицу, то есть при каждом append .

А вообще, не хорошо в представлении писать невалидные поля. Благо, что это JavaScript.




Для Django рекомендую VDS-хостинг TIMEWEB

0

пробовал. В этом случае сначала идет рефреш старой модели, потом скрипт, потом отображение новой. Но ошибки из-за рефреша все равно идут. 

То есть похоже рефреш происходит в момент выполнения функции view_all_tree.model=seaPhones;


В принципе я могу все модели привести к набору одинаковых полей. Тогда ошибок не будет. Но почему происходит рефреш ListView с привязкой к старой модели, когда там уже новые данные. Вот вопрос

0

Я бы ещё попробовал написать или два разных представления, или два разных делегате, и менял бы делегаты в зависимости от устанавливаемой модели.

Для Django рекомендую VDS-хостинг TIMEWEB

0
  • The answer was marked as a solution.
  • Nov. 1, 2018, 6:48 a.m.

В делегатах слишком много кода. Я просто понаписал фиктивных полей в моделей - чтобы не было ошибок. И все оставил как есть.

0

Answers

Only authorized users can respond to the forum.
Please, login or register
Nov. 16, 2018, 7:09 p.m.
Илья Завьялов

Qt - Test 001. Signals and slots

  • Result:31points,
  • Rating scores-10
Nov. 16, 2018, 12:49 p.m.
Ирина Минигузина

C++ - Тест 003. Условия и циклы

  • Result:0points,
  • Rating scores-10
Nov. 16, 2018, 8:55 a.m.
Vitaliy

Qt - Test 001. Signals and slots

  • Result:52points,
  • Rating scores-4
Recent comments
Nov. 16, 2018, 6:50 a.m.
Евгений Легоцкой

Добрый день! шаблон не находит, или шаблон неправильно прописали, или тег шаблона неправильно написан, иных выводов сделать не могу, из того, что вы написали. трейсбек нужно смотреть. Со...
Nov. 16, 2018, 6:48 a.m.
Евгений Легоцкой

пройтись циклом по всем виджетам в обратном порядке for (int i = ui->vertialLayout->count() - 1; i >= 0; --i){ QWidget* w = ui->verticalLyout->itemAt(i)->widget();...
Nov. 15, 2018, 9:35 p.m.
chunk

Доброго времени суток Евгений. Не подскажете что я делаю не так? Получаю ошибку такого характера: Reverse for 'add_comment' with arguments '('',)' not found. 1 pattern(s) tried: ...
Nov. 15, 2018, 3:35 p.m.
Михаиллл

Спасибо. Похоже где то описку сделал, поэтому не работало. Я добавил на verticalLayout много виджитов. А можно ли их как то быстро и просто удалить?
Nov. 15, 2018, 2:55 p.m.
Евгений Легоцкой

verticalLayout - это, по-моему предположению, должен быть у вас объект класса QVBoxLayout, который наследован от QBoxLayout. Поэтому открываете документацию на QVBoxLayout ...
Now discuss on the forum
Nov. 16, 2018, 4:28 p.m.
Евгений Легоцкой

Добрый день! Спасибо, что воспользовались именно форумом. Заниматься курсовыми работами чьими-то ни было у меня времени нет, у самого полторы работы. Но что-то подсказать на фо...
Nov. 16, 2018, 9:52 a.m.
Евгений Легоцкой

Отладчик!!!! Версия комплекта MSVC 2015 + компилятор 14.0!!!!
Nov. 14, 2018, 3:25 p.m.
Михаиллл

вот решение // grab the model QStandardItemModel* model = qobject_cast<QStandardItemModel*> ( ui->combobox->model() ); if (!model) { // check is important or u can/might ...
Nov. 14, 2018, 7:56 p.m.
Евгений Легоцкой

Добрый день! QGripSize целится на окно, но никак не на виджет. Здесь можно кастомную вьюшку написать. Вот в этой статье есть пример написания собственного ресайза ....
Join us in social networks

For registered users on the site there is a minimum amount of advertising