使用XML创建dojo.store.memory?

时间:2014-06-22 13:05:48

标签: javascript xml dojo.gridx dojo

我的数据最初存储在这样结构的xml文件中(包含一堆实体,每个实体中的行和每行中的单元格)

    <entity i=1>
        <row i =1>
           <cell i=1>
           <cell i=2>
        </row>

        <row i=2>
           <cell i=1>
           <cell i=2>
        </row>
    </entity>

示例我从dojo教程中读到的是:

    require([

    'dojo/store/Memory',
    'gridx/Grid',
    'gridx/core/model/cache/Sync'
    ], function(Store, Grid, Cache){
  var store = new Store({
    data: [
        {id: 1, title: 'Hey There', artist: 'Bette Midler'},
        {id: 2, title: 'Love or Confusion', artist: 'Jimi Hendrix'},
        {id: 3, title: 'Sugar Street', artist: 'Andy Narell'}
    ]
});
......
});

我应该如何使用XML样式表创建dojo商店?我应该在XML样式表中使用嵌入式javascript吗?

1 个答案:

答案 0 :(得分:0)

好吧,您可以使用dojo/query模块来遍历XML文档。您首先要做的就是解析XML(如果它还没有),例如:

require([ "dojo/query", "dojox/xml/parser", "dojo/dom-attr" ], function(query, xml, domAttr) {
    var content = xml.parse("<entity><row i=\"1\"><cell i=\"1\">Cell 1</cell><cell i=\"2\">Cell 2</cell></row><row i=\"2\"><cell i=\"1\">Cell 3</cell><cell i=\"2\">Cell 4</cell></row></entity>");
    var out = query("row", content).map(function(node) {
        var data = {};
        query("cell", node).forEach(function(cell) {
            data[domAttr.get(cell, "i")] = cell.textContent;
        });
        return data;
    });
    console.log(out);
});

这将生成两个对象的数组,其中i属性的值是属性名称,<cell>元素的文本内容是值。

[{
  "1": "Cell 1",
  "2": "Cell 2"
}, {
  "1": "Cell 3",
  "2": "Cell 4"
}]

然后您可以在商店中使用。

可以在JSFiddle上找到完整的示例:http://jsfiddle.net/bUjN7/