ngRepeat:dupes错误,虽然没有重复

时间:2015-11-20 16:58:35

标签: javascript json angularjs angularjs-ng-repeat

我有一个像下面的HTML代码,我在其中使用AngularJS框架:

<select name="choose-staff" ng-model="admin_times[0].user"  ng-change="update(reserve.staff)" id="choose-staff">
     <option ng-repeat="value in staff | unique:'employee.user.username'" value="{[{ value.employee.user.username }]}">{[{ value.employee.user.first_name }]} {[{ value.employee.user.last_name }]}</option>
</select>

我收到这样的错误:

Duplicates in a repeater are not allowed. Use 'track by' expression to specify unique keys. Repeater: value in staff | unique:'employee.user.username', Duplicate key: string:ب, Duplicate value: ب

如果我使用track by $index它会破坏我想要的结构,当我点击其中一个选项时,其余部分就会消失。

[
    {
        "employee": {
            "user": {
                "id": 3,
                "first_name": "اشکان",
                "last_name": "وکیلی",
                "user_profile": null,
                "username": "ashkan"
            },
            "business": {
                "id": "caf241cd-adb4-44ee-8c40-0f6cdb3bc5ac",
                "fa_name": "ساینا",
                "en_name": "Saina",
                "service": [],
                "persian_address": "",
                "location": "35.77885523664743,51.39051060551765",
                "avatar": null,
                "email": ""
            },
            "is_head": true
        },
        "service": {
            "en_title": "Haircut",
            "fa_title": "کوتاهی مو"
        },
        "allocated_time": 60,
        "booked_no": "XG4OCX81"
    },
    {
        "employee": {
            "user": {
                "id": 3,
                "first_name": "اشکان",
                "last_name": "وکیلی",
                "user_profile": null,
                "username": "ashkan"
            },
            "business": {
                "id": "caf241cd-adb4-44ee-8c40-0f6cdb3bc5ac",
                "fa_name": "ساینا",
                "en_name": "Saina",
                "service": [],
                "persian_address": "",
                "location": "35.77885523664743,51.39051060551765",
                "avatar": null,
                "email": ""
            },
            "is_head": true
        },
        "service": {
            "en_title": "Color",
            "fa_title": "رنگ مو"
        },
        "allocated_time": 25,
        "booked_no": "1AY3F24G"
    },
    {
        "employee": {
            "user": {
                "id": 2,
                "first_name": "رضا",
                "last_name": "ولیمرادی",
                "user_profile": {
                    "id": "9d9be03a-f840-46ea-a21e-76cd5775a886",
                    "avatar": null,
                    "city": "",
                    "gender": "F",
                    "birthday": null,
                    "country": "IR",
                    "about": "",
                    "timestamp": "2015-11-06T14:56:10.312340Z",
                    "location": "36.03133177633187,51.328125"
                },
                "username": "reza"
            },
            "business": {
                "id": "caf241cd-adb4-44ee-8c40-0f6cdb3bc5ac",
                "fa_name": "ساینا",
                "en_name": "Saina",
                "service": [],
                "persian_address": "",
                "location": "35.77885523664743,51.39051060551765",
                "avatar": null,
                "email": ""
            },
            "is_head": false
        },
        "service": {
            "en_title": "Yellow",
            "fa_title": "زرد"
        },
        "allocated_time": 15,
        "booked_no": "H989M93X"
    },
    {
        "employee": {
            "user": {
                "id": 1,
                "first_name": "علیرضا",
                "last_name": "غفاری",
                "user_profile": {
                    "id": "884b36e3-7bad-466f-afee-25801572b834",
                    "avatar": null,
                    "city": "",
                    "gender": "F",
                    "birthday": null,
                    "country": "IR",
                    "about": "",
                    "timestamp": "2015-11-06T14:56:39.522362Z",
                    "location": "32.24997445586331,53.26171875"
                },
                "username": "alireza"
            },
            "business": {
                "id": "caf241cd-adb4-44ee-8c40-0f6cdb3bc5ac",
                "fa_name": "ساینا",
                "en_name": "Saina",
                "service": [],
                "persian_address": "",
                "location": "35.77885523664743,51.39051060551765",
                "avatar": null,
                "email": ""
            },
            "is_head": true
        },
        "service": {
            "en_title": "Color",
            "fa_title": "رنگ مو"
        },
        "allocated_time": 20,
        "booked_no": "O5KLFPZB"
    }
]

我不喜欢employee.user.username

的冗余

1 个答案:

答案 0 :(得分:0)

在我看来,每个对象的唯一值是booked_no

在这种情况下,您应该使用track by value.booked_no