admin管理员组文章数量:1345473
So I've got an object called "options" with these items in it:
var options = {
assignments: ['involved', 'assignee', 'candidate'],
assignment: ""
}
With a for loop, I'm trying to put the values from my array assignments in the assignment var, one by one. Then I'm using "options" with the new value as parameters for another function I'm calling inside my loop.
for (var i = 0; i < options.data.assignments.length; i++) {
options.data.assignment = options.data.assignments[i];
console.log("value of i : ",i);
console.log("value of options :",options);
otherFunction(options);
}
I was expecting to see results like this :
value of i : 0
value of options : {assignment = "involved"...}
value of i : 1
value of options : {assignment = "assignee"...}
value of i : 2
value of options : {assignment = "candidate"...}
But instead I have something like this :
value of i : 0
value of options : {assignment = "candidate"...}
value of i : 1
value of options : {assignment = "candidate"...}
value of i : 2
value of options : {assignment = "candidate"...}
The thing is while doing that my assignment variable is always set to "candidate", the value at the end of my array.
The strange thing is when I'm trying to console.log(options.data.assignments[i])
, the right value shows up. Same for the "i", it goes from 0 to 1 then 2 and stops properly. So my loop is working perfectly fine, except when I want to set the value of my variable.
Any ideas what's the problem here?
Thanks
So I've got an object called "options" with these items in it:
var options = {
assignments: ['involved', 'assignee', 'candidate'],
assignment: ""
}
With a for loop, I'm trying to put the values from my array assignments in the assignment var, one by one. Then I'm using "options" with the new value as parameters for another function I'm calling inside my loop.
for (var i = 0; i < options.data.assignments.length; i++) {
options.data.assignment = options.data.assignments[i];
console.log("value of i : ",i);
console.log("value of options :",options);
otherFunction(options);
}
I was expecting to see results like this :
value of i : 0
value of options : {assignment = "involved"...}
value of i : 1
value of options : {assignment = "assignee"...}
value of i : 2
value of options : {assignment = "candidate"...}
But instead I have something like this :
value of i : 0
value of options : {assignment = "candidate"...}
value of i : 1
value of options : {assignment = "candidate"...}
value of i : 2
value of options : {assignment = "candidate"...}
The thing is while doing that my assignment variable is always set to "candidate", the value at the end of my array.
The strange thing is when I'm trying to console.log(options.data.assignments[i])
, the right value shows up. Same for the "i", it goes from 0 to 1 then 2 and stops properly. So my loop is working perfectly fine, except when I want to set the value of my variable.
Any ideas what's the problem here?
Thanks
Share Improve this question edited Jun 20, 2020 at 9:12 CommunityBot 11 silver badge asked Jul 9, 2018 at 12:35 BlueWillBlueWill 291 gold badge1 silver badge3 bronze badges 10-
1
options.data.assignment = options.data.assignments[i];
makes no sense.... you are reassigning what you are looping over? It is going to be the last value because the loop ends at the last value. – epascarello Commented Jul 9, 2018 at 12:37 - 3 When you assign to a variable, you replace the old value with the new value. What is it that you expect to happen? – Pointy Commented Jul 9, 2018 at 12:37
-
2
@BlueWill : First of all It should be
options.assignments
and notoptions.data.assignments
, assuming your snippet is correct. – BeingExpert Commented Jul 9, 2018 at 12:38 - 2 what is your assignment variable supposed to look like after the loop? – T A Commented Jul 9, 2018 at 12:39
-
1
@BlueWill - nobody knows what you want
options.data.assignment
to actually be/contain after the loop. Please clear that up. – Adam Jenkins Commented Jul 9, 2018 at 12:44
4 Answers
Reset to default 6for (var i = 0; i < options.data.assignments.length; i++) {
options.data.assignment = options.data.assignments[i];
}
will loop 3 times:
options.data.assignment = options.data.assignments[0]
->options.data.assignment='involved'
options.data.assignment = options.data.assignments[1]
->options.data.assignment='assignee'
options.data.assignment = options.data.assignments[2]
->options.data.assignment='candidate'
So in fact, you are assigning 3 different data one by one to the same value, so, in the end options.data.assignment
will be the last value of your loop.
Here is what you do with a easier example :
var a = 0;
for (var i = 0; i < 3; i++) {
a = i;
}
as you can see, in the end the variable a
will always be the last value of the loop i
.
First of all It should be options.assignments
and not options.data.assignments
.
Here is something you want
var options = {
assignments: ['involved', 'assignee', 'candidate'],
assignment: ""
}
for (var i = 0; i < options.assignments.length; i++) {
options.assignment = options.assignments[i];
console.log("value of i : ",i);
console.log("value of options :", options);
// otherFunction(options);
}
Here is what i get :
As you can see, my assignment is changing
You are assigning to the same var everything, replacing the previous values as you go along. If you just want to concatenate all elements from the array to the string you can do this
for (var i = 0; i < options.data.assignments.length; i++) {
options.data.assignment += options.data.assignments[i]+',';
}
EDIT: as said by @puzhi : You can also do this to take care of the last ',' without removing it after
options.data.assignment = options.data.assignments.join(',')
you are reassigning same variable with each iteration in loop thats why last value gets assigned after third loop.
You can simply do this to achieve what you need.
options.data.assignment = options.data.assignments.map(ele=>ele)
var options = {
assignments: ['involved', 'assignee', 'candidate'],
assignment: ""
}
for (var i = 0; i < options.assignments.length; i++) {
options.assignment += options.assignments[i]+";"; //updated the assignment operator to get desired result
}
console.log(options.assignment);
本文标签: javascriptFor loop only shows last value of arrayStack Overflow
版权声明:本文标题:javascript - For loop only shows last value of array - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1743782497a2538074.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论