Here are all types of for loops in JS: // for for (let i = 0; i < arr.length; i++) { // i is index, arr[i] is element } // for ..in for (let i in arr) { // i is index, arr[i] is element } // for ..of for (let elt of arr) { // index not available, elt is element } // forEach arr.forEach((elt, i) => { // i is index, elt is element });
If you count forEach you should count the other iterative methods. Stuff like map, filter, find, every, some and all the rest. The word for in forEach doesn’t really matter. Right? Array.map() may as well be called forEachElementToArray. And you’ll want to be familiar with a while loop and recursive looping. “These are the loops with for in the name” isn’t a significant thing. What you mean is “these are the ways to loop” and there are lots more ways to loop than you find with the keyword for. 👍
This is different from the foreach loop in that the foreach only works with arrays whereas this for of loop works with any iterable, there is a third called the for..in loop for the curious
Since you did get me curious and no one has already mentioned it. A quick search tells me that a for/in loop is used to iterate over several properties of a single object. For example an object (person) might have a few different kinds of properties: let person = { name: "John", age: 22, occupation: "Accountant" } You can iterate over those properties like this: let text; for (let prop in person) { text += person[prop] + " "; } console.log(text); The person object is treated like an array containing all those properties that you are iterating over. The result of that loop will print: "John 22 Accountant " Keep in mind that these properties may not be of the same type. In this case the age property is an integer while the others are strings.
And also .foreach and .map array method (map has a return value while foreach has not - not to be confused with Map variable). So 6 *(SIX)* ways to iterate over arrays/objects/maps. Yeah, JavaScript is confusing.
With all the comments about forEach, I was amused to find that "each" is not a reserved word in JavaScript. So you could write: for (let each of bubbles) { each.move(); each.show(): }
I always thought that foreach was analogous to the implementation Python uses on its for loops, but watching this video I realize that "for of" is closer to Python's for than the Javascript's foreach. That is because Python can loop to any iterative object (not only arrays of things, but characters in a string, or generated elements in a lazy function that yields a value when it is called). Nice!
Thank you Dan, I just want to add there is also for (in) syntax but you still have to use [i] in it. for (let i in bubbles) { bubbles[i].move(); bubbles[i].show(); } this also does the same thing. Peace
Beautiful explanation!!! You have exactly answered my question!!! So the name(variable) for each element in an array is completely arbitrary!! Very nice, short and concise video! Thank you!!
Maybe when you cover iterables, you can come back to this and explain how it works in a little more detail. I liked how you explained the convention of naming the elements. That might be confusing for a beginner. ES6 is awesome! Oh, I almost forgot! With the for-of loop, the element variable can be declared with const, so may as well!
Lots of functionality gets introduced. This was a part of ES6 from 2015 if I remember right. Then there was ES7, 8, and 9. Keep an eye out for new releases.
i really dont understand why Dan despises so much of foreach loop. look how excited he gets when he uses the foreach functionality under a different name. seriously wth?
Just the title here has taught me something completely new I know that in other programming languages there’s a syntax like for element in array, but i never realized this exact same thing exists in javascript, just the actual in keyword which returns the key of the item, not the value, so i always had ugly code like this: for (i in array) { const element = array[i] // other code } But thanks to this video i now know of the much more efficient and easier to read: for (element of array) { // other code }
It's funny that Homer (yes, the Illiad and Odyssey one), had very similar objections as you have at the and of the video. He was afraid of ruining the poem by putting it in written form, and not having control over the time/audiance issue.
Quick yet very important question: what would you recommend for new programmers to start thinking programmatically? In other words. the way you explain this FOR...Of loop, how did you there?
Ed Farage works slightly differently I think in that you can use a foreach to loop over key/value pairs this looks to be a little less detailed. Probably quicker as a result..
yes, except (in my opinion) it's a lot cleaner, and also allows you to properly use break/continue but you could argue methods like .filter() or .find() remove the need for break/continue entirely, so in the end, it's just preference whichever you use, since they all give the same end result ¯\_(ツ)_/¯
oh god I"m having trouble with the syntax and you have three words that are all essentially the same word bubble Bubbles and bubbles, my man you have added an element of confusion my smooth brain did not need
Dan, FYI, You mentioned the choice of "of" instead of "in". Actually, ES6 does allow "for .. in". Using this syntax, you get an index into the array instead of an array element. In other words it's a shorter way of writing "for (let i = 0; i < bubbles.length; i++)", as you still refer to bubbles[i]. Except I you can't mess with i inside the loop. Well you can, but at the next loop iteration, it ignores anything you did to i. Not sure what happens if you delete elements.
There is also a thing called for...in loop Example: let obj={ hello:"abcde", one:"fghijk" }; let abc=""; for(const key in obj){ abc+=obj[key]; } console.log(abc); //abcdefghijk
for...in is, like you mentioned, already in use and enables you to loop through keys in an javascript object:) Also please keep in mind that theese more abstract functions have a greater impact on performance (for...of is ~80% slower than a regular for loop) This is usually something you don need to talk into account but there are cases where performance is everything
peavyibanez: *for...of* is not slower when you consider that it extracts the element of the array in addition to looping. I just tested the following on a 1,000,000 element array: *t = new Date().getTime(); for (x of a) {}; console.log (new Date().getTime() - t);* That ran in 124 ms. But *t = new Date().getTime(); for (i = 0; i < a.length; i++) {var x = a[i];}; console.log (new Date().getTime() - t);* took 616ms, or about 5 times *longer* !
Ken Haley Good point. However, usually there is even more. The runtime compiler is very smart nowadays and *should* (hopefully) optimize loops anyway. So it should not matter what you are actually using. But it's a thing to consider if you run into performance issues.
Hey Dan! i was wondering ,is if it is posible to open my processing sckech in my web browser? but enyways great video i always come back every time thanks so much for doing this!
This new form of the loop is like a foreach, I would like to know if it is possible to display the index or if I myself should create a variable outside and count?
lieberscott it's cleaner, you don't need an auxiliar variable to iterate through the elements of the array, don't have to specify the length... It just iterates through all the array, with a less verbose syntax
OK.... This is sorta what I came up with... it works, but I dunno if anything bad is happening that I can't see!!! function mousePressed() { for (let ball of balls) { if (dist(mouseX, mouseY, ball.x, ball.y) < ball.r) { let index = balls.indexOf(ball); balls.splice(index, 1); } } }
Prior versions of js had "foreach", which iterates over the items of an Array object, and "for in", which iterates over the properties of an object. The new "for of" iterates over the items of any iterable object (i.e. any object that implements "Symbol.iterator"). Example using a generator: class myIterable { *[Symbol.iterator] () { yield 1; yield 2; yield 3; } } for (let item of new myIterable()) { document.write(item + ""); } Example using a custom iterator: class myIterator { constructor(data) { this.data = data; this.index = 0; } next() { if (this.index < this.data.length) { return { value: this.data[this.index++], done: false } } else { this.index = 0; return { done: true }; } } } class myIterable2 { [Symbol.iterator]() { return new myIterator([1, 2, 3]); } } for (let item of new myIterable2()) { document.write(item + ""); } A valid iterator is any object with a "next" function, with the following signature: () => { value: any, done: boolean } The "let" keyword is a separate thing. It solves a lot of scoping issues, so I'd recommend reading the docs on it.
Why you do not have to Set any datatypes to Work with in p5? like , Set Bubbles as integer or Set Bubbles as Byte? Is there a Standard datatype in the global settings? I work with a Hobbyist Language namens BASCOM and i have to declare every non Compiler Word (or letter) for a datatype. This is confusing me why you dont use datatype Setting at all.
DIYman In javascript you don't have to specify data types as these are assigned by the program (you need to use var,let or const but it works for everything) and thats why javascript is so good in my opinion :V It slows down everything for sure, like c++ is one of fastest languages and here you must specify data type.
Yeah, no its Older then c , c+ and c++. I dont use Waved brackets and semicolons in my code, then it´s called BASCOM BASIC. Maybe from the late 1970´s^^
Why don’t you just use map() filter() and/or reduce(), in addition to forEach and for...of, when you need to manipulate an array instead of the traditional counting method?
when should I use for in and when for of? Let say I have a json file and i extract it to a variable in js. can i iterate through every key of the object? for (key of obj) { console.log(key) console.log(obj[key]); } or for (key in obj) { console.log(key) console.log(obj[key]); } ? ie the json file looks sth like this, it’s not complex { „name”: „Grzegorz”, „regex”: „\w+” „property2”: „iterable” } really just key and a property...
Use "for in" to iterate over the properties of an object. Use "for of" to iterate over the items of a collection. Example: let json = { "name": "Grzegorz", "regex": "\w+", "hobbies": [ "Programming", "Bug hunting" ] }; document.write("Keys:") for (let key in json) { document.write(key + ""); } document.write("Hobbies:") for (let item of json.hobbies) { document.write(item + ""); }
'for in' is used to loop over object properties and also over arrays but it's not recommended if the order of the items of arrays is important given that 'for in' iterates in random order and 'for of' is used just for built-in types, for custom objects we have to implement ourselves the generator function for our custom object.
Hayttman use for (var obj of objs) is slow than for (var i = 0; i < array.length; i++) To improve the last example, I can save the length from array in another variable and use it to compare, like this: for (var i = 0, len = array.length; i < len; i++) // it works faster
But you are in the future, I don't even know who you are, watching this video. But you are there, someday, watching this video. I'm probably not standing here anymore, I'm somewhere else. This video has ended. I don't know how to feel about this sentence
Gordon Chin it's actually a lot simpler, but it's just a pain to get your head around at first. All you do is make a variable and assign it the first item in the array. Then as soon as you hit the end of the block, go to the next item in the array! I'm usually a Python guy, and it's much easier to read. Try reading this as English for every_bubble in my_bubbles: every_bubble.show() every_bubble.move() It's the same thing in JS, except there are all those (ugly) brackets and braces everywhere.
if look up iterables objects and emunerable properties that will satisfy the difference. developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/for...of
Here are all types of for loops in JS:
// for
for (let i = 0; i < arr.length; i++) {
// i is index, arr[i] is element
}
// for
..in
for (let i in arr) {
// i is index, arr[i] is element
}
// for
..of
for (let elt of arr) {
// index not available, elt is element
}
// forEach
arr.forEach((elt, i) => {
// i is index, elt is element
});
Thank you so much. Sometimes all I need from a tutorial is a good example and this was four great examples.
If you count forEach you should count the other iterative methods. Stuff like map, filter, find, every, some and all the rest.
The word for in forEach doesn’t really matter.
Right?
Array.map() may as well be called forEachElementToArray.
And you’ll want to be familiar with a while loop and recursive looping.
“These are the loops with for in the name” isn’t a significant thing. What you mean is “these are the ways to loop” and there are lots more ways to loop than you find with the keyword for. 👍
I love how this guy articulates this stuff. It really makes it click.
"But you are in the future..." that part made me feel like you are directly talking to me.
THANK YOU SO MUCH FOR TEACHING ME THIS!
It all made sense now!
I love you from the future! Unicorn! Rainbow!
Finally I met the "foreach" equivalent in JavaScript. It looks so cool compared with the traditional for loop with "i".
This is different from the foreach loop in that the foreach only works with arrays whereas this for of loop works with any iterable, there is a third called the for..in loop for the curious
Thank you for this info!!
wow that's actually very handy
Since you did get me curious and no one has already mentioned it. A quick search tells me that a for/in loop is used to iterate over several properties of a single object.
For example an object (person) might have a few different kinds of properties:
let person = {
name: "John",
age: 22,
occupation: "Accountant"
}
You can iterate over those properties like this:
let text;
for (let prop in person) {
text += person[prop] + " ";
}
console.log(text);
The person object is treated like an array containing all those properties that you are iterating over. The result of that loop will print:
"John 22 Accountant "
Keep in mind that these properties may not be of the same type. In this case the age property is an integer while the others are strings.
Yeah it mostly gets used to iterate through objects
And also .foreach and .map array method (map has a return value while foreach has not - not to be confused with Map variable).
So 6 *(SIX)* ways to iterate over arrays/objects/maps.
Yeah, JavaScript is confusing.
With all the comments about forEach, I was amused to find that "each" is not a reserved word in JavaScript.
So you could write:
for (let each of bubbles) {
each.move();
each.show():
}
@善有善报Wade B. to each his own. Or should I say "for each his own?" 😂
Its hilarious how you time travel. Really educational videos. Thanks for doing these.
"I don't feel like counting today"
made my day :D
I always thought that foreach was analogous to the implementation Python uses on its for loops, but watching this video I realize that "for of" is closer to Python's for than the Javascript's foreach. That is because Python can loop to any iterative object (not only arrays of things, but characters in a string, or generated elements in a lazy function that yields a value when it is called). Nice!
I love how you gae me valuable lesson of coding, some nice joke and a quick existancial crisis just in under four minutes
Thank you Dan,
I just want to add there is also for (in) syntax but you still have to use [i] in it.
for (let i in bubbles) {
bubbles[i].move();
bubbles[i].show();
}
this also does the same thing.
Peace
Beautiful explanation!!! You have exactly answered my question!!! So the name(variable) for each element in an array is completely arbitrary!! Very nice, short and concise video! Thank you!!
I'm here now 'from the future', watching your video now! THANKS
Maybe when you cover iterables, you can come back to this and explain how it works in a little more detail. I liked how you explained the convention of naming the elements. That might be confusing for a beginner. ES6 is awesome! Oh, I almost forgot! With the for-of loop, the element variable can be declared with const, so may as well!
Thanks! Love the energy!
I didn't think it was possible for you to make videos this short!
I always get something from you, I have never heard of For Of before and here you are amazing me again, oh man thank you so much.
Lots of functionality gets introduced. This was a part of ES6 from 2015 if I remember right.
Then there was ES7, 8, and 9.
Keep an eye out for new releases.
Wow that was the deepest ending of a video ever in the history of youtube
Great 👍🏽 video ! Great enthusiasm! SUBSCRIBED !
never thought of enhanced loops in js, good to know they exist now
Thanks from the future. I love your humour man
You're the biggest nerd I've ever seen ;). I love your videos. You're amazing!
i really dont understand why Dan despises so much of foreach loop.
look how excited he gets when he uses the foreach functionality under a different name.
seriously wth?
I agree this is odd behavior.
Helped clear it up, thanks!
Just the title here has taught me something completely new
I know that in other programming languages there’s a syntax like for element in array, but i never realized this exact same thing exists in javascript, just the actual in keyword which returns the key of the item, not the value, so i always had ugly code like this:
for (i in array) {
const element = array[i]
// other code
}
But thanks to this video i now know of the much more efficient and easier to read:
for (element of array) {
// other code
}
wow i really dont follow your time flow, But i do understand the code !! Thank you this is awesome
It's funny that Homer (yes, the Illiad and Odyssey one), had very similar objections as you have at the and of the video. He was afraid of ruining the poem by putting it in written form, and not having control over the time/audiance issue.
Quick yet very important question: what would you recommend for new programmers to start thinking programmatically? In other words. the way you explain this FOR...Of loop, how did you there?
isn't this just foreach?
Ed Farage works slightly differently I think in that you can use a foreach to loop over key/value pairs this looks to be a little less detailed. Probably quicker as a result..
exactly what i thought, except for forEach giving you an index as second parameter
yes, except (in my opinion) it's a lot cleaner, and also allows you to properly use break/continue
but you could argue methods like .filter() or .find() remove the need for break/continue entirely, so in the end, it's just preference whichever you use, since they all give the same end result ¯\_(ツ)_/¯
fun fact, .entries() is also a thing
for (const [index, bubble] of bubbles.entries()) {
// ...
}
kingdaro yeah I try to use arr.entries() whenever I can. JavaScript is such a great language!!
oh god I"m having trouble with the syntax and you have three words that are all essentially the same word bubble Bubbles and bubbles, my man you have added an element of confusion my smooth brain did not need
intro of the video like doc brown from back to the future am here to tell u about the future!!!
very good, thank you
Finally a properly foreach in javaScript, the current foreach is kind like "strange" haha
Very nice teacher
I saw you used let in declaration of for loop at 0:44. But in for loops var still works faster.
The purpose of *let* isn't performance, it's to control scope. The difference in speed is usually negligible.
Dan, FYI, You mentioned the choice of "of" instead of "in". Actually, ES6 does allow "for .. in". Using this syntax, you get an index into the array instead of an array element. In other words it's a shorter way of writing "for (let i = 0; i < bubbles.length; i++)", as you still refer to bubbles[i]. Except I you can't mess with i inside the loop. Well you can, but at the next loop iteration, it ignores anything you did to i. Not sure what happens if you delete elements.
Ah yes thank you for this clarification!!
this guy is the Bill Nye of coding.
That last part gave me an existential crisis
There is also a thing called for...in loop
Example:
let obj={
hello:"abcde",
one:"fghijk"
};
let abc="";
for(const key in obj){
abc+=obj[key];
}
console.log(abc); //abcdefghijk
I use that all the time
for...in is, like you mentioned, already in use and enables you to loop through keys in an javascript object:)
Also please keep in mind that theese more abstract functions have a greater impact on performance (for...of is ~80% slower than a regular for loop)
This is usually something you don need to talk into account but there are cases where performance is everything
peavyibanez: *for...of* is not slower when you consider that it extracts the element of the array in addition to looping. I just tested the following on a 1,000,000 element array:
*t = new Date().getTime(); for (x of a) {}; console.log (new Date().getTime() - t);*
That ran in 124 ms. But
*t = new Date().getTime(); for (i = 0; i < a.length; i++) {var x = a[i];}; console.log (new Date().getTime() - t);*
took 616ms, or about 5 times *longer* !
Ken Haley
Good point.
However, usually there is even more. The runtime compiler is very smart nowadays and *should* (hopefully) optimize loops anyway. So it should not matter what you are actually using. But it's a thing to consider if you run into performance issues.
Hey Dan! i was wondering ,is if it is posible to open my processing sckech in my web browser? but enyways great video i always come back every time thanks so much for doing this!
This new form of the loop is like a foreach, I would like to know if it is possible to display the index or if I myself should create a variable outside and count?
I'm here in one of your futures 4 years later 😂
Wow I love this
I'm here. Hello from the future, I hope everything goes well!
Amazing
Hello, from the future asking a question, I would've loved if you shed some light on using 'continue' with for of loops.
Love your video
awesome!
this is very python like syntax and i like it.
and what it is move() and show()? it looks like methods of "bubble" object but how it works with bubbles?
so it's like the foreach loop
Any reason why you would use a "for of" loop over a for (let i = 0; i < array.length; i++) loop?
lieberscott it's cleaner, you don't need an auxiliar variable to iterate through the elements of the array, don't have to specify the length... It just iterates through all the array, with a less verbose syntax
It's both easier to type and easier to read! I have always hated the former syntax, that originated in C.
it's the foreach loop, isn't it ?
How to you remove items from array with for...of loop? Do you still use splice or some other method?
OK.... This is sorta what I came up with... it works, but I dunno if anything bad is happening that I can't see!!!
function mousePressed() {
for (let ball of balls) {
if (dist(mouseX, mouseY, ball.x, ball.y) < ball.r) {
let index = balls.indexOf(ball);
balls.splice(index, 1);
}
}
}
Is it okay for me to assume that we use for (of) for looping element in array in all or most cases and for(in) to loop keys inside an object?
I think that's right!
I thought JS or P5js already had a for each loop. Is this somehow specifically for the Let variable?
Prior versions of js had "foreach", which iterates over the items of an Array object, and "for in", which iterates over the properties of an object.
The new "for of" iterates over the items of any iterable object (i.e. any object that implements "Symbol.iterator").
Example using a generator:
class myIterable {
*[Symbol.iterator] () {
yield 1;
yield 2;
yield 3;
}
}
for (let item of new myIterable()) {
document.write(item + "");
}
Example using a custom iterator:
class myIterator {
constructor(data) {
this.data = data;
this.index = 0;
}
next() {
if (this.index < this.data.length) {
return { value: this.data[this.index++], done: false }
}
else {
this.index = 0;
return { done: true };
}
}
}
class myIterable2 {
[Symbol.iterator]() {
return new myIterator([1, 2, 3]);
}
}
for (let item of new myIterable2()) {
document.write(item + "");
}
A valid iterator is any object with a "next" function, with the following signature: () => { value: any, done: boolean }
The "let" keyword is a separate thing. It solves a lot of scoping issues, so I'd recommend reading the docs on it.
what's the difference with a "for...in" loop?
the theacher is from the past or from the future?? i am shocked of this return to the future/past
how do you loop against number ex.
for(x = 1; x
✅
This works like pythons for loop, doesn't it? Very handy to know that this exists in Java as well! Thanks!
llaaoopp I dont think that this is Java...
this is JavaScript, which is different from Java. if this would be coded in Java it would be "for (Bubble n : bubbles){}"
JavaScript***
For .. of .. is used to iterate on Iterators .. custom iterator or Async iterator ..
please make a SAT Collision ( Polygon and Polygon, Polygon and Circle ...) tutorial! Tks
intresting teaching sir i am from pakistan
Why you do not have to Set any datatypes to Work with in p5? like , Set Bubbles as integer or Set Bubbles as Byte? Is there a Standard datatype in the global settings? I work with a Hobbyist Language namens BASCOM and i have to declare every non Compiler Word (or letter) for a datatype. This is confusing me why you dont use datatype Setting at all.
DIYman In javascript you don't have to specify data types as these are assigned by the program (you need to use var,let or const but it works for everything) and thats why javascript is so good in my opinion :V It slows down everything for sure, like c++ is one of fastest languages and here you must specify data type.
Yeah, no its Older then c , c+ and c++. I dont use Waved brackets and semicolons in my code, then it´s called BASCOM BASIC. Maybe from the late 1970´s^^
Why don’t you just use map() filter() and/or reduce(), in addition to forEach and for...of, when you need to manipulate an array instead of the traditional counting method?
It's a good point! I hope to explore these array functions soon.
when should I use for in and when for of?
Let say I have a json file and i extract it to a variable in js.
can i iterate through every key of the object?
for (key of obj) {
console.log(key)
console.log(obj[key]);
} or
for (key in obj) {
console.log(key)
console.log(obj[key]);
} ?
ie the json file looks sth like this, it’s not complex
{
„name”: „Grzegorz”,
„regex”: „\w+”
„property2”: „iterable”
} really just key and a property...
Use "for in" to iterate over the properties of an object.
Use "for of" to iterate over the items of a collection.
Example:
let json = {
"name": "Grzegorz",
"regex": "\w+",
"hobbies": [
"Programming",
"Bug hunting"
]
};
document.write("Keys:")
for (let key in json) {
document.write(key + "");
}
document.write("Hobbies:")
for (let item of json.hobbies) {
document.write(item + "");
}
Anders Kehlet thanks for the answer
JavaScript na basic video make I like it
You should REALLY make clear what's the difference between for...of and *for...in* loops.
This is an excellent point, I should do another video to clarify.
'for in' is used to loop over object properties and also over arrays but it's not recommended if the order of the items of arrays is important given that 'for in' iterates in random order and 'for of' is used just for built-in types, for custom objects we have to implement ourselves the generator function for our custom object.
Please have your video translated into Spanish which is very good and there are too many people who need it, kind regards
Why didnt you also tell that it accepts "key" and "value" of the iterable (like foreach)?
for (let [key, value] of something) { ... }
I did not know this! I might need to make this video over again!
The below syntax would work the exact same:
for(var i in bubbles){
bubbles[i].move()
bubbles[i].show()
}
Hayttman this way is slow than a common for loop
Wanderson Silva so is the of loop he showed in the video
Hayttman use for (var obj of objs) is slow than for (var i = 0; i < array.length; i++)
To improve the last example, I can save the length from array in another variable and use it to compare, like this: for (var i = 0, len = array.length; i < len; i++) // it works faster
Very common in Angular
Dang. This helps me so much. But I still use Array.prototype.forEach. Yes I know it's slower.
This is like the enhanced for loop In java
for (var prop in obj)
you are cool guy
!)
sit I like ur teaching
But you are in the future, I don't even know who you are, watching this video. But you are there, someday, watching this video. I'm probably not standing here anymore, I'm somewhere else. This video has ended.
I don't know how to feel about this sentence
sometimes I think that this dude is a little bit insane
instead of calling it "unicorn",
I name it objBubble
makes it more readable imo
I want to get into software engineering but it looks so damn hard
nerds are the best
You are funny
very similar with python :)
Uncaught ReferenceError: elt is not defined that is what is telling me
finally don't have to use [ ]
is there a guy like this dude tgat teaches C/C++?
some now
Ugh that's really confusing syntax.
Gordon Chin it's actually a lot simpler, but it's just a pain to get your head around at first.
All you do is make a variable and assign it the first item in the array. Then as soon as you hit the end of the block, go to the next item in the array!
I'm usually a Python guy, and it's much easier to read. Try reading this as English
for every_bubble in my_bubbles:
every_bubble.show()
every_bubble.move()
It's the same thing in JS, except there are all those (ugly) brackets and braces everywhere.
You probably didnt use Java(*not meant javascript*) before?
let r;
let bubbles=[];
function setup() {
createCanvas(600, 400);
}
function draw() {
background(0);
for(let i=0;i
if look up iterables objects and emunerable properties that will satisfy the difference. developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/for...of
I’m here in 2020
JS every day they release new built-in function
10 likes just for the ending! haha
I know where you are 😉
i am from the future.