这是我的数据集:
dfg= [[{"key":"Product_Description","value":"$49.95 Plan"},{"key":">20MB/30","value":44555},{"key":">200MB/30","value":36599},{"key":">2048MB/30","value":16173},{"key":">5120MB/30","value":6380},{"key":">10240MB/30","value":2178}],[{"key":"Product_Description","value":"$39.95 Plan"},{"key":">20MB/30","value":54832},{"key":">200MB/30","value":42988},{"key":">2048MB/30","value":14826},{"key":">5120MB/30","value":4742},{"key":">10240MB/30","value":1567}]]
我想通过此函数传递它,以便将上面的值更改为“产品描述”总值的百分比
//funtion to format data for percent values
function format_data_to_percent(d){
var data = d
data.map(function(a){
var sum = a.slice(1).map(function(a){ return a.value; }).reduce(function(a,b){return a*1+b*1},0);
//console.log("sum",sum);
a.slice(1).filter(function(a){
//console.log(a)
a.value=a.value/sum
//console.log(a)
});
return a;
})
//START TEST
// create a test case for it // make this better
vals=data_p[0].slice(1).map(function(a){ return a.value; })
//["11", "33", "10", "55", "10"]
sum = data_p[0].slice(1).map(function(a){ return a.value; }).reduce(function(a, b){return a*1+b*1},0);
//119
vals2=vals.map(function(a){ return a/sum})
//[0.09243697478991597, 0.2773109243697479, 0.08403361344537816, 0.46218487394957986, 0.08403361344537816]
console.log("test1--> ",data[0][1].value == vals2[0])
console.log("test2--> ",data[0][2].value == vals2[1])
console.log("test3--> ",data[0][3].value == vals2[2])
console.log("test4--> ",data[0][4].value == vals2[3])
console.log("test5--> ",data[0][5].value == vals2[4])
//END TEST
return data
}
dfg2=format_data_to_percent(dfg) //format my dataset
这就是我得到的,这就是我想要的东西
[[{"key":"Product_Description","value":"$49.95 Plan"},{"key":">20MB/30","value":0.42078670255465833},{"key":">200MB/30","value":0.345648581007697},{"key":">2048MB/30","value":0.15274118147046323},{"key":">5120MB/30","value":0.06025404920432545},{"key":">10240MB/30","value":0.02056948576285593}],[{"key":"Product_Description","value":"$39.95 Plan"},{"key":">20MB/30","value":0.4609474170904964},{"key":">200MB/30","value":0.3613803539153461},{"key":">2048MB/30","value":0.12463536631499307},{"key":">5120MB/30","value":0.03986381404732882},{"key":">10240MB/30","value":0.013173048631835568}]]
但是dfg也等于df2,我希望dfg保持与数字和dfg2一样保持百分比。
我正在做的事情不是最好的做法。我明白,虽然没有像我想的那样完整,但是数组中的对象都是相同的引用。 但有没有办法可以用数值和dfg2用百分比值来实现dfg?
我来到了this,并通过切片原件来复制数组。我试过这个,但它在我的情况下不起作用,也许在那里没有对象的例子,而我的数组中有对象。
EDIT1 可能重复here但这更像是java。 This可能是我想要的
直接分配数组时,它是一个引用赋值 JavaScript的。这意味着任何更改都将反映在两者中。至 复制一个数组,你需要调用array.slice()。
注意:这仍然是多维数组的赋值, 所以你需要写一些递归的东西来复制一个数组 有一个以上的维度(在任何元素,例如[1,2,['some', 'inner','array'],3])
到下面的anser: 仅供参考,这里是我的浏览器的完整日志
dfg
[[Object { key="Product_Description", value="$100.83 Business Select Plan excl GST"}, Object { key=">20MB/30", value=1480}, Object { key=">200MB/30", value=1234}, 3 more...], [Object { key="Product_Description", value="$119.95 Business Share Everything Plan"}, Object { key=">20MB/30", value=66}, Object { key=">200MB/30", value=57}, 3 more...]]
var arr2 = []
undefined
arr2.push(JSON.parse(JSON.stringify(dfg[0])))
1
arr2.push(JSON.parse(JSON.stringify(dfg[1])))
2
arr2
[[Object { key="Product_Description", value="$100.83 Business Select Plan excl GST"}, Object { key=">20MB/30", value=1480}, Object { key=">200MB/30", value=1234}, 3 more...], [Object { key="Product_Description", value="$119.95 Business Share Everything Plan"}, Object { key=">20MB/30", value=66}, Object { key=">200MB/30", value=57}, 3 more...]]
//funtion to format data for percent values func...alue == vals2[4]) //END TEST return data }
undefined
var arr3 = format_data_to_percent(arr2)
test1--> true
test2--> true
test3--> true
test4--> true
test5--> true
undefined
arr3
[[Object { key="Product_Description", value="$100.83 Business Select Plan excl GST"}, Object { key=">20MB/30", value=0.37336024217961655}, Object { key=">200MB/30", value=0.3113017154389506}, 3 more...], [Object { key="Product_Description", value="$119.95 Business Share Everything Plan"}, Object { key=">20MB/30", value=0.3815028901734104}, Object { key=">200MB/30", value=0.32947976878612717}, 3 more...]]
dfg
[[Object { key="Product_Description", value="$100.83 Business Select Plan excl GST"}, Object { key=">20MB/30", value=1480}, Object { key=">200MB/30", value=1234}, 3 more...], [Object { key="Product_Description", value="$119.95 Business Share Everything Plan"}, Object { key=">20MB/30", value=66}, Object { key=">200MB/30", value=57}, 3 more...]]
答案 0 :(得分:3)
克隆数组?这样你就可以获得原始数组的副本,而不是对原始数组的引用数组。
如果您正在使用jquery,则可以使用.extend
var array_1 = [{},{},{}];
var array_2 = $.extend({}, true, array_1); // deep clone
或者你可以使用一些新的JavaScript。虽然这只是执行浅拷贝,所以可能不适合您的用例,我在移动应用程序上,因此无法使用您的代码..
var array_2 = Object.assign({}, array_1);
答案 1 :(得分:1)
您可以克隆数组的对象。
例如:
var arr = [{'one': 1}, {'two': 2}];
var arr2 = [];
arr2.push(JSON.parse(JSON.stringify(arr[0])));
arr2现在将使用JSON.parse w / JSON.stringify拥有arr [0]的独立副本。您可以使用for循环,为每个或映射复制原始数组中的所有对象。