由Javascript填充的QML ListView

由Javascript填充的QML ListView,javascript,listview,qml,Javascript,Listview,Qml,我刚刚意识到(根据一些QML错误报告),ListView缺少JSON委托。所以我有两个选择,用Javascript或C创建的模型填充它++ 特别是我需要从预定义的URL下载.json数据,并将它们解析到ListView 我试图用Javascript创建对象数组,并将assoc数组作为模型推送到ListView,但失败了。不管我如何修改代码 P>>是否只有C++解决方案,或者我可以用JavaScript? 谢谢 我试过的代码: return [{"name":"value"}] return {

我刚刚意识到(根据一些QML错误报告),ListView缺少JSON委托。所以我有两个选择,用Javascript或C创建的模型填充它++

特别是我需要从预定义的URL下载.json数据,并将它们解析到ListView

我试图用Javascript创建对象数组,并将assoc数组作为模型推送到ListView,但失败了。不管我如何修改代码

<> P>>是否只有C++解决方案,或者我可以用JavaScript? 谢谢

我试过的代码:

return [{"name":"value"}]
return {"name":"value"}
return [["name","value"]]

问题始终是:
ReferenceError:由于来自的建议,无法找到变量:name

mouli@irc.freenode.net#请执行以下操作:

文件:gui.qml

import "script.js" as Script

model: ListModel { id: list_model_id }
文件:script.js

function makeList(id){
    id.append({"name":"value1"});
    id.append({"name":"value2"});
}
电话:

Script.makeList(list_model_id)
它更易于使用:


这可能有点晚,但使用Qt 5.5(可能更早,但使用5.5测试),您可以执行以下操作:

假设您有这样一个数组:
var-dataArray=[{“name”:“A”},{“name”:“B”},{“name”:“C”}]

QML中显示此模型的代码:

ListView {
    model: dataArray //the array from above
    delegate: Label {
        text: dataArray[index].name
    }
}

将为学员提供
索引。它是模型中当前项的索引。有关更多信息,请参阅。

FYI:我做了同样的事情,但没有使用javascript:
ListView {
    model: dataArray //the array from above
    delegate: Label {
        text: dataArray[index].name
    }
}