2

考虑这个 JSON

{
    "stream": {
        "posts": [{
            "post_id": "1",
            "post_type": "text",
            "post_thumb": "bla1",
            "comments": [{
                "comment_id": "7",
                "comment_text": "asd",
            },
            {
                "comment_id": "8",
                "comment_text": "sdf",
            }],
        }],
    }
}

和我的模特

Ext.define('MyAppApp.model.Post', {
    extend: 'Ext.data.Model',
    config: {
        fields: [
            'post_id',
            'post_type',
            'post_thumb',
            'comments',
        ],
        proxy: {
            type: 'jsonp',
            url:  'http://MyApp.com/home/index_app',
            reader: {
                type:         'json',
                rootProperty: 'stream'
            }
        }
    }
});

以上正确显示了我认为的帖子列表。我添加了一个控制器来推送一个面板以显示每个帖子的全部内容,这是有效的。

控制器

Ext.define('MyAppApp.controller.Main', {
    extend: 'Ext.app.Controller',

    config: {
        refs: {
            stream: 'homepanel'
        },
        control: {
            'homepanel list': {
                itemtap: 'showPost'
            }
        }
    },

    showPost: function(list, index, element, record) {

/////// begin code block that solved my problem

    var data     = record.get('comments');
    var comments = '';

    Ext.Array.each(data, function(item) {
        comments += [item.comment_text] + '<br />';
    });

/////// end 

        this.getStream().push({
            xtype: 'panel',
            html: [
                '<p>' + record.get('post_thumb') + '</p>',
                '<p>' + record.get('comments') + '</p>',
                comments     // added to output HTML
            ].join(''),
            scrollable: true,
            styleHtmlContent: true,
        });
    }
});

我的麻烦是从 中检索数据comments,这些数据嵌套在 JSON 中。

使用上面的控制器,我得到

[object Object],[object Object]

在我看来,在控制台中,我可以打开这些对象并查看我的全部评论。

但是如何在视图中显示它们?(例如,我如何显示"comment_text"?)

4

2 回答 2

2

好吧,一旦它们在您的模型中,它们就不再是 JSON,它们被反序列化为对象。要显示它们,您应该使用XTemplate。如果您已经在视图中使用了模板,则可以直接访问对象的属性来渲染它们。如果还有什么不清楚的,请告诉我。

为什么你自己将内容渲染到 html 属性中?这是性能原因的原因吗?我不习惯ST,所以我问。无论如何,构建一个小辅助函数,它将遍历注释数组并返回或多或少格式化的字符串(这取决于你,还要检查数组是否至少为空且永远不会为空)

var data = record.get('comments')
function(data) {
    var result = '',
        len = data.length,
        i=0;

    for(;i<len;i++) {
        result += data[i]['comment_text'] +'<br />'
    }

    return result;
}

下面是 origin 函数的一个实现。我发布这个原因是不推荐使用 Ext.Array.each,因为它为每个元素执行一个函数,并且应该避免循环内的函数调用。

showPost: function(list, index, element, record) {
        var data     = record.get('comments');

        function fetchComments(data) {
            var result = '',
                len = data.length,
                i = 0;

            for(;i<len;i++) {
                result += data[i]['comment_text'] + '<br />';
            }

            return result;
        }

        this.getStream().push({
            xtype: 'panel',
            html: [
                '<p>' + record.get('post_thumb') + '</p>',
                '<p>' + fetchComments(data) + '</p>'
            ].join(''),
            scrollable: true,
            styleHtmlContent: true,
        });
    }
于 2012-09-23T12:14:55.483 回答
1

这是我迭代的另一种方式。

json数据:

{
    "account" : [
        {
            "id": "1",
            "accNo" : "5869785254",
            "curAmt" : "25000",
            "balAmt" : "15000",
            "transdate" : [
                {
                    "date" : "10",
                    "month" : "03",
                    "description" : "Check 232",
                    "crddbt" : "-1200"
                },
                {
                    "date" : "14",
                    "month" : "03",
                    "description" : "ATM Withdrawl",
                    "crddbt" : "-500"
                }
            ],
        }
    ]
}

Sencha 代码迭代转换对象。

var transDateObj = record.get('transdate');

Ext.Object.each(transDateObj, function(key, value, myself){

            Ext.Object.each(value, function(key, value, myself){
                console.log(key + ":" + value);
            });
        });
于 2012-10-06T13:56:48.893 回答