0

我正在尝试创建 2 个空白对象,运行一个填充其中 1 个的 php 循环,然后将这些对象扩展在一起......最终创建 1 个对象,其中包含许多对象。

这是逻辑/代码(注意,服务器的东西是专有的,但它运行 php 并且工作正常):

var allUsers = {};
var singleUser = {};

$(document).ready(function(){

<fm:UserList 
    fields="id,firstname,lastname,geo_latitude,geo_longitude,meta,externalids"
> 

    <fm:Loop> 

        singleUser = {
            'index'             : '{$loop.index}',
            'id'                : '{$user.id}',
            'firstname'         : '{$user.firstname}',
            'lastname'          : '{$user.lastname}',
            'geo_latitude'      : '{$user.geo_latitude}',
            'geo_longitude'     : '{$user.geo_longitude}',
            'company'           : '{$user.meta.company}',
            'twitter'           : '{$user.meta.twitter}',
            'externalprovider'  : '{$user.externalids.0.external_id_provider}',
            'externalid'        : '{$user.externalids.0.external_parsed_id}'

        }
        /* Merge singleUser into allUsers */
        $.extend(allUsers,singleUser);

    </fm:Loop>
</fm:UserList>

console.log(allUsers);
});

这是页面上的内容:

var allUsers = {};
var setUser = {};

    $(document).ready(function(){

        setUser = {
            'index'             : '0',
            'id'                : '1930039',
            'firstname'         : 'Devo',
            'lastname'          : 'Brown',
            'geo_latitude'      : '-46.81610453612681',
            'geo_longitude'     : '-70.6640625',
            'company'           : 'Filemobile',
            'twitter'           : 'devinbrownca',
            'externalprovider'  : '',
            'externalid'        : ''

        }
        /* Merge setUser into passed allUsers */
        $.extend(allUsers,setUser);



        setUser = {
            'index'             : '1',
            'id'                : '1930025',
            'firstname'         : 'Aidan',
            'lastname'          : 'Roach',
            'geo_latitude'      : '51.032184898096396',
            'geo_longitude'     : '-108.6328125',
            'company'           : '',
            'twitter'           : '',
            'externalprovider'  : '',
            'externalid'        : ''

        }
        /* Merge setUser into passed allUsers */
        $.extend(allUsers,setUser);



        setUser = {
            'index'             : '2',
            'id'                : '1930024',
            'firstname'         : 'Devin',
            'lastname'          : 'Brown ',
            'geo_latitude'      : '42.89743256946478',
            'geo_longitude'     : '-101.6015625',
            'company'           : '',
            'twitter'           : '',
            'externalprovider'  : '',
            'externalid'        : ''

        }
        /* Merge setUser into passed allUsers */
        $.extend(allUsers,setUser);

console.log(allUsers);
});

在函数结束时,控制台只记录一个对象,即最后创建的对象。

知道我做错了什么吗?

4

4 回答 4

2

$.extend将一个对象的属性复制到另一个对象。

我想你需要一个数组

var allUsers = [];

 /* Push singleUser into allUsers */
 allUsers.push(singleUser);
于 2013-09-05T21:07:17.453 回答
2

$.extend 所做的是将两个或多个对象的内容(字段)合并到第一个对象中。似乎 allUsers 不应该是一个哈希(对象),而是一个数组。因此,您将推动用户参与其中:

var allUsers = [];

allUsers.push(singleUser);
于 2013-09-05T21:11:31.087 回答
1

这种行为正是这样extend做的。对象的任何新属性setUser都会添加到 中allUsers,但现有属性会被覆盖。例如:

    setUser = {
        'firstname'         : 'Devo',
        'index'             : '0',
    }
    $.extend(allUsers,setUser);

    setUser = {
        'index'             : '1',
        'id'                : '1930039'
    }
    $.extend(allUsers,setUser);

将导致以下对象:

    allUsers = {
        'firstname'         : 'Devo',
        'index'             : '1',
        'id'                : '1930039'
    }

所以,问题是:想要这段代码做什么?

如果您只想跟踪所有用户,您可能只想保留一组setUser对象,如下所示:

allUsers = [
            {
               'id':'0',
                ...
            },
            {
               'id':'1',
                ...
            },
            {
               'id':'2',
               ...
            }
           ];

您可以通过将每个setUser对象推入allUsers数组来实现这一点,如下所示:

allUsers = [];

setUser = {...};
allUsers.push(setUser);

但是,如果您想要一个allUsers对象,每个属性都有一组值,如下所示:

    allUsers = {
        'firstname'         : ['Devo', 'Aidan'],
        'index'             : ['0','1'],
        ...
    }

您需要推出自己的功能。

您的问题的另一种解决方案可能是保留allUsers为对象,但为每个用户对象使用键:

allUsers = {
    '1930039' = {
        'index'             : '0',
        'firstname'         : 'Devo',
        'lastname'          : 'Brown',
        ...
    },
    '1930025' = {
        'index'             : '1',
        'firstname'         : 'Aidan',
        'lastname'          : 'Roach',
        ...
    },
    ...
}
于 2013-09-05T21:07:33.813 回答
0
var allUsers = [];
var singleUser = {};

$(document).ready(function(){
<fm:UserList 
    fields="id,firstname,lastname,geo_latitude,geo_longitude,meta,externalids"
    geo="notnull"
> 

    <fm:Loop> 

        singleUser = {
            'index'             : '{$loop.index}',
            'id'                : '{$user.id}',
            'firstname'         : '{$user.firstname}',
            'lastname'          : '{$user.lastname}',
            'geo_latitude'      : '{$user.geo_latitude}',
            'geo_longitude'     : '{$user.geo_longitude}',
            'company'           : '{$user.meta.company}',
            'twitter'           : '{$user.meta.twitter}',
            'externalprovider'  : '{$user.externalids.0.external_id_provider}',
            'externalid'        : '{$user.externalids.0.external_parsed_id}'

        }
        /* push singleUser object into allUsers array */
        allUsers.push(singleUser);
    </fm:Loop>
</fm:UserList>
于 2013-09-05T21:14:51.197 回答