gpt4 book ai didi

javascript - 在 AngularJS 中将对象文字保存到 localStorage

转载 作者:行者123 更新时间:2023-12-03 04:06:14 26 4
gpt4 key购买 nike

我正在尝试将此对象保存到 $window.localStorage() 中:

Ctrl:

app.controller('ctrl', function($window, $scope) {

$scope.initData = [
{
customer: 1,
firstName: "John",
lastName: "Doe"
},
{
customer: 2,
firstName: "Jane",
lastName: "Doe"
},
{
customerId: 3,
firstName: "John",
lastName: "Smith",

}
];

// scopes

for(var i = 0; i < $scope.initData.length; ++i) {
$window.localStorage.setItem(i, JSON.stringify($scope.initData[i]));
}
});

但是我得到了以键作为索引的值..我也尝试过这个:

for(var i = 0; i < $scope.initData.length; ++i) {
$window.localStorage.setItem(i, Object.values($scope.initData[i]));
}

并使用for..in,但无法找出最好的方法。

现在,当我执行 console.log(localStorage); 时,我将其作为输出:

0:"{"customer":1,"firstName":"John","lastName":"Doe"}"
1:"{"customer":2,"firstName":"Jane","lastName":"Doe"}"
2:"{"customer":3,"firstName":"John","lastName":"Smith"}"

当我访问 0 作为键时,我得到 customer 作为值,并且我需要获取 1 作为值。 客户应该是关键。

我怎样才能实现这个目标?我该如何转换它?

最佳答案

只需将对象 $scope.initData 完全保存到 localStorage 中即可,我没有看到单独保存 initData 对象的优势。在应用程序加载时从 localStorage 加载客户,并在更新时保存它们。但不要直接从 localStorage 工作 - 我会在此之上使用 service

// Set localStorage item
localStorage.setItem('initData', JSON.stringify(dataObject));

// Retrieve the object from localStorage
var retrievedObject = localStorage.getItem('initData');

// console.log retrieved item
console.log('retrieved data Object: ', JSON.parse(retrievedObject));

或者您可以将 key 更改为如下内容(以客户唯一 ID 作为引用),而不是循环计数器:

for(var i = 0; i < $scope.initData.length; ++i) {
$window.localStorage.setItem('customer-id' + $scope.initData[i].customer, JSON.stringify($scope.initData[i]));
}
});

关于javascript - 在 AngularJS 中将对象文字保存到 localStorage,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44540188/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com