首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >更改AngularJS中的嵌套对象值会更改所有其他值

更改AngularJS中的嵌套对象值会更改所有其他值
EN

Stack Overflow用户
提问于 2019-12-01 14:04:02
回答 1查看 62关注 0票数 0

考虑以下嵌套对象,它循环10次,为给定时间的每个星期一生成一个具有10周计划的对象:

代码语言:javascript
运行
复制
$rootScope.bookings_times_list = [];
for (i = 0; i < 10; i++) {    
    $rootScope.bookings_times_list.push({
        week: i,
        schedule: [{
            booking_day: "Monday",
            booking_times: [{
                "booking_start_time": "00:15",
                "booking_end_time": "01:00",
                "booking_selected": "",
                "booking_selected_date": "",
                "booking_time": "30 Nov 2019 07:35hrs"
            }]
        }]                         
    });
}

问题是,将booking_selected值更改为1,如下所示,将每周所有booking_selected键的值更改为1

$rootScope.bookings_times_list[0].schedule[0].booking_times[0].booking_selected = 1;

$rootScope.bookings_times_list[0]的密钥在第一周明显设置为0时,为什么会发生这种情况?

====UPDATE====

实际代码以空预订时间开始,如下所示:

代码语言:javascript
运行
复制
$rootScope.bookings_times_list = [];
for (i = 0; i < 10; i++) {    
    $rootScope.bookings_times_list.push({
        week: i,
        schedule: [{
            booking_day: "Monday",
            booking_times: []
        }]                         
    });
}

接下来是另一个for循环,它连接了星期一并添加了从预订中获得的实际时间安排:

代码语言:javascript
运行
复制
for (a = 0; a < $rootScope.bookings_times_list.length; a++) {
    for (y = 0; y < $rootScope.bookings_times_list[a].schedule.length; y++) {
        if($rootScope.business_bookings[$rootScope.bookings_index].booking_times[y]){
            var index = $rootScope.bookings_times_list[a].schedule.findIndex(x => x.booking_day === $rootScope.business_bookings[$rootScope.bookings_index].booking_times[y].booking_day);

            if(index >= 0){
                $rootScope.bookings_times_list[a].schedule.splice(index, 1, $rootScope.business_bookings[$rootScope.bookings_index].booking_times[y]);
            }
         }
    }
} 

第二个for循环似乎是造成问题的原因。剪接是否影响对象的初始化方式?

===UPDATE===

我也注意到问题不在于剪接。因为从

代码语言:javascript
运行
复制
$rootScope.bookings_times_list[a].schedule.splice(index, 1, $rootScope.business_directory_records[$rootScope.index].business_bookings[$rootScope.bookings_index].booking_times[y]);

代码语言:javascript
运行
复制
$rootScope.bookings_times_list[a].schedule[index] = $rootScope.business_directory_records[$rootScope.index].business_bookings[$rootScope.bookings_index].booking_times[y]

在第二个for循环中,仍然会产生相同的问题。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-12-01 15:39:16

使用angular.copy

代码语言:javascript
运行
复制
 .splice(index, 1, angular.copy(monday));

angular.copy函数创建不共享其内容的新对象。

有关详细信息,请参阅

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59126239

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档