JSONListModel
Jump to navigation
Jump to search
JSONListModel is a pure-QML component that allows using JSON data as datasource for a QML ListView.
Code
The JSONListModel code is Open Source and available under the MIT license at:
"github.com/kromain/qml-utils":https://github.com/kromain/qml-utils
Features
- mimics the XMLListModel component by providing similar API and properties
- supports both source-based and string-based JSON data
- support complex JSON documents and queries via JSONPath (XPath for JSON)
Example
With a file jsonData.txt containing:
<br />{ "store&quot;: {<br /> "book&quot;: [<br /> { "category&quot;: "reference&quot;,<br /> "author&quot;: "Nigel Rees&quot;,<br /> "title&quot;: "Sayings of the Century&quot;,<br /> "price&quot;: 8.95<br /> },<br /> { "category&quot;: "fiction&quot;,<br /> "author&quot;: "Evelyn Waugh&quot;,<br /> "title&quot;: "Sword of Honour&quot;,<br /> "price&quot;: 12.99<br /> },<br /> { "category&quot;: "fiction&quot;,<br /> "author&quot;: "Herman Melville&quot;,<br /> "title&quot;: "Moby Dick&quot;,<br /> "isbn&quot;: "0-553-21311-3&quot;,<br /> "price&quot;: 8.99<br /> },<br /> { "category&quot;: "fiction&quot;,<br /> "author&quot;: "J. R. R. Tolkien&quot;,<br /> "title&quot;: "The Lord of the Rings&quot;,<br /> "isbn&quot;: "0-395-19395-8&quot;,<br /> "price&quot;: 22.99<br /> }<br /> ],<br /> "bicycle&quot;: {<br /> "color&quot;: "red&quot;,<br /> "price&quot;: 19.95<br /> }<br /> }<br />}<br />
We can write:
<br /> JSONListModel {<br /> id: jsonModel1<br /> source: "jsonData.txt&quot;<br /> // All books in the store object<br /> query: "$.store.book[*]"<br /> }
JSONListModel {<br /> id: jsonModel2<br /> source: "jsonData.txt&quot;<br /> // Books less than $10<br /> query: "$..book[?(
.price<10)]"
}
JSONListModel {
id: jsonModel3
json: '[ {"label": "Answer", "value": "42"}, {"label": "Pastis", "value": "51"}, {"label": "Alsace", "value": "67"}, {"label": "Alsace", "value": "68"} ]'
// Labels starting with 'A'
query: "$[?(
.label.charAt(0)==='A')]"<br /> }<br />
And use it in views and delegates like this:
<br /> ListView {<br /> model: jsonModel1.model
delegate: Component {<br /> Text {<br /> // Can be any of the JSON properties: model.author, model.price, etc.<br /> text: model.title<br /> }<br /> }<br />