Dynamically create ListModel in QML

前端 未结 3 1221
花落未央
花落未央 2021-02-05 22:37

When I need to create any QML component in runtime, I can use that guide: http://qt-project.org/doc/qt-5/qtqml-javascript-dynamicobjectcreation.html

i.e. just call Qt.cr

相关标签:
3条回答
  • 2021-02-05 22:48

    I am a JS developer who writes QtQuick applications and this is something I have tried on with multiple solutions.

    Short answer to managing models in JavaScript inside QML is that it's a nightmare. I would advice you to write a small sub-class of QAbstractListModel which internally uses QJsonArray as its data source, so that it makes it easier to understand the data structure in C++ as well as in its usage inside QML. Follow the instructions to create QML types from C++ here.

    If you still want to do it inside JavaScript, another approach is the following:

    function createNewList() {
        var newListModel = Qt.createQmlObject('import QtQuick 2.2; \
            ListModel {}', parent);
        return newListModel;
    }
    

    However this has some serious memory leak problems even after using gc()

    If your primary concern is having ListModels inside ListModels, this following simple thing works for me (there is an implicit type conversion between array of objects and ListModels inside ListModels I think)

    property ListModel items: ListModel {}
    
    function addComplexItem() {
        items.append({
            "key": "People",
            "arr": [
                {
                 "arrItemName": "John",
                 "arrItemValue": 18,
                },
                {
                 "arrItemName": "Kerry",
                 "arrItemValue": 21,
                },
                {
                 "arrItemName": "Mike",
                 "arrItemValue": 19,
                }    
            ]});
    }
    
    
    // Usage
    Component {
        id: viewDelegate
    
        Item {
            Text {
                text: "List of " + key
            }
            ListView {
                model: arr
                delegate: Rectangle {
                    Text { 
                        text: arrItemName
                    } 
                }
            }  
        }
    }
    
    0 讨论(0)
  • 2021-02-05 22:51

    Try this:

    Component {
        id: someComponent
        ListModel {
        }
    }
    
    function createModel(parent) {
        var newModel = someComponent.createObject(parent);
        return newModel;
    }
    
    0 讨论(0)
  • 2021-02-05 23:05

    I do the initialization like this:

    dataObject_m1.initSystem= function() { // QML calls when ready 
      console.log( "ModulData_1.js func initSystem()");
    
      dataObject_m1.statisticsSystem= Qt.createQmlObject("import QtQuick 2.5; ListModel{}", dataObject_m1.parent, "dynamic_source" );
      dataObject_m1.statisticsSystem.objectName = "ModelSystem";
      dataObject_m1.statisticsSystem.append( { name: qsTr("System"), number: "", val: ""});
      dataObject_m1.statisticsSystem.append( { name: "S3500", number: "", val: ""});
      dataObject_m1.statisticsSystem.append( { name: "S3550", number: "", val: ""});
      dataObject_m1.statisticsSystem.append( { name: "S3551", number: "", val: ""});
      dataObject_m1.statisticsSystem.append( { name: "S9999", number: "", val: ""});
    }    
    

    And to update Data:

     var updateSystem = function ( numberMap , valMap) {
         console.log ("ModuleData_1.js: updateSystem" );
    
       for (var num in (numberMap )) {
          var j = dataObject_m1.idMap[num];
          dataObject_m1.statisticsSystem.set( j, { val : Map[num]});
          console.log ("number(" + numberMap[val]+ ") [" + String(j) + "]= numbeMap["+val+"]" )
      }
     for (var valx in (valMap)) {
         var k = dataObject_m1.idMap[valx];
         dataObject_m1.statisticsSystem.set( k, { bad : valMap[valx]});
         console.log ("val(" + valMap[valx]+ ") [" + String(k) + "]= valMap["+valx+"]" )
      }
    }
    

    Access fuction to model:

     var statisticsModelSystem= function()  {
        console.log ("ModulData_1.js: get statisticsModelSystem" );
        if ( typeof(dataObject_m1.statisticsSystem) !== 'object')
            console.error(" statisticsSystem is undefined ")
    
        return dataObject_m1.statisticsSystem;
    }
    
    0 讨论(0)
提交回复
热议问题