JavaScript scoping rules: how to use clearInterval() inside a callback
I am trying to learn JS using a course on PluralSight, and I found this example which prints "hello world" every second, and stops after 5 seconds. This is the intended solution, and it works.
let counter = 0;
const intervalId = setInterval(() => {
console.log('Hello World');
counter += 1;
if (counter === 5) {
console.log('Done');
clearInterval(intervalId);
}
}, 1000);
I am trying to get it to use a callback instead of an inline function, but I am not able to capture intervalID. I tried passing 'this' as function argument, but that also doesn't work. What is the correct way here?
// doesn't work
let counter = 0;
const f = (intervalID) => {
console.log("Hello World");
counter += 1
console.log(intervalID)
if (counter ==5){
console.log("Done")
clearInterval(intervalID)
}
}
const intervalID = setInterval(f, 1000)
javascript
add a comment |
I am trying to learn JS using a course on PluralSight, and I found this example which prints "hello world" every second, and stops after 5 seconds. This is the intended solution, and it works.
let counter = 0;
const intervalId = setInterval(() => {
console.log('Hello World');
counter += 1;
if (counter === 5) {
console.log('Done');
clearInterval(intervalId);
}
}, 1000);
I am trying to get it to use a callback instead of an inline function, but I am not able to capture intervalID. I tried passing 'this' as function argument, but that also doesn't work. What is the correct way here?
// doesn't work
let counter = 0;
const f = (intervalID) => {
console.log("Hello World");
counter += 1
console.log(intervalID)
if (counter ==5){
console.log("Done")
clearInterval(intervalID)
}
}
const intervalID = setInterval(f, 1000)
javascript
Remove theintervalID
parameter. The first parameter tosetInterval
isA function to be executed every delay milliseconds. The function is not passed any parameters, and no return value is expected.
– CertainPerformance
Jan 3 at 1:18
add a comment |
I am trying to learn JS using a course on PluralSight, and I found this example which prints "hello world" every second, and stops after 5 seconds. This is the intended solution, and it works.
let counter = 0;
const intervalId = setInterval(() => {
console.log('Hello World');
counter += 1;
if (counter === 5) {
console.log('Done');
clearInterval(intervalId);
}
}, 1000);
I am trying to get it to use a callback instead of an inline function, but I am not able to capture intervalID. I tried passing 'this' as function argument, but that also doesn't work. What is the correct way here?
// doesn't work
let counter = 0;
const f = (intervalID) => {
console.log("Hello World");
counter += 1
console.log(intervalID)
if (counter ==5){
console.log("Done")
clearInterval(intervalID)
}
}
const intervalID = setInterval(f, 1000)
javascript
I am trying to learn JS using a course on PluralSight, and I found this example which prints "hello world" every second, and stops after 5 seconds. This is the intended solution, and it works.
let counter = 0;
const intervalId = setInterval(() => {
console.log('Hello World');
counter += 1;
if (counter === 5) {
console.log('Done');
clearInterval(intervalId);
}
}, 1000);
I am trying to get it to use a callback instead of an inline function, but I am not able to capture intervalID. I tried passing 'this' as function argument, but that also doesn't work. What is the correct way here?
// doesn't work
let counter = 0;
const f = (intervalID) => {
console.log("Hello World");
counter += 1
console.log(intervalID)
if (counter ==5){
console.log("Done")
clearInterval(intervalID)
}
}
const intervalID = setInterval(f, 1000)
javascript
javascript
asked Jan 3 at 1:16
Harshdeep GuptaHarshdeep Gupta
186
186
Remove theintervalID
parameter. The first parameter tosetInterval
isA function to be executed every delay milliseconds. The function is not passed any parameters, and no return value is expected.
– CertainPerformance
Jan 3 at 1:18
add a comment |
Remove theintervalID
parameter. The first parameter tosetInterval
isA function to be executed every delay milliseconds. The function is not passed any parameters, and no return value is expected.
– CertainPerformance
Jan 3 at 1:18
Remove the
intervalID
parameter. The first parameter to setInterval
is A function to be executed every delay milliseconds. The function is not passed any parameters, and no return value is expected.
– CertainPerformance
Jan 3 at 1:18
Remove the
intervalID
parameter. The first parameter to setInterval
is A function to be executed every delay milliseconds. The function is not passed any parameters, and no return value is expected.
– CertainPerformance
Jan 3 at 1:18
add a comment |
1 Answer
1
active
oldest
votes
Your intervalID
is not an argument passed to f
, but if you just remove the argument it will work because the intervalID
is lexically scoped so that it's available inside f
.
let counter = 0;
const f = () => {
console.log("Hello World");
counter += 1
console.log(intervalID)
if (counter ==5){
console.log("Done")
clearInterval(intervalID)
}
}
const intervalID = setInterval(f, 1000)
OR passing in the intervalID
is also fine:
let counter = 0;
const f = (intervalID) => {
console.log("Hello World");
counter += 1
console.log(intervalID)
if (counter ==5){
console.log("Done")
clearInterval(intervalID)
}
}
const intervalID = setInterval(() => f(intervalID), 1000)
Thanks a lot, the lexical scoping in JavaScript is really different. I don't even understand how is that possible! Can you explain a little bit more about it?
– Harshdeep Gupta
Jan 3 at 1:40
add a comment |
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f54015182%2fjavascript-scoping-rules-how-to-use-clearinterval-inside-a-callback%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
Your intervalID
is not an argument passed to f
, but if you just remove the argument it will work because the intervalID
is lexically scoped so that it's available inside f
.
let counter = 0;
const f = () => {
console.log("Hello World");
counter += 1
console.log(intervalID)
if (counter ==5){
console.log("Done")
clearInterval(intervalID)
}
}
const intervalID = setInterval(f, 1000)
OR passing in the intervalID
is also fine:
let counter = 0;
const f = (intervalID) => {
console.log("Hello World");
counter += 1
console.log(intervalID)
if (counter ==5){
console.log("Done")
clearInterval(intervalID)
}
}
const intervalID = setInterval(() => f(intervalID), 1000)
Thanks a lot, the lexical scoping in JavaScript is really different. I don't even understand how is that possible! Can you explain a little bit more about it?
– Harshdeep Gupta
Jan 3 at 1:40
add a comment |
Your intervalID
is not an argument passed to f
, but if you just remove the argument it will work because the intervalID
is lexically scoped so that it's available inside f
.
let counter = 0;
const f = () => {
console.log("Hello World");
counter += 1
console.log(intervalID)
if (counter ==5){
console.log("Done")
clearInterval(intervalID)
}
}
const intervalID = setInterval(f, 1000)
OR passing in the intervalID
is also fine:
let counter = 0;
const f = (intervalID) => {
console.log("Hello World");
counter += 1
console.log(intervalID)
if (counter ==5){
console.log("Done")
clearInterval(intervalID)
}
}
const intervalID = setInterval(() => f(intervalID), 1000)
Thanks a lot, the lexical scoping in JavaScript is really different. I don't even understand how is that possible! Can you explain a little bit more about it?
– Harshdeep Gupta
Jan 3 at 1:40
add a comment |
Your intervalID
is not an argument passed to f
, but if you just remove the argument it will work because the intervalID
is lexically scoped so that it's available inside f
.
let counter = 0;
const f = () => {
console.log("Hello World");
counter += 1
console.log(intervalID)
if (counter ==5){
console.log("Done")
clearInterval(intervalID)
}
}
const intervalID = setInterval(f, 1000)
OR passing in the intervalID
is also fine:
let counter = 0;
const f = (intervalID) => {
console.log("Hello World");
counter += 1
console.log(intervalID)
if (counter ==5){
console.log("Done")
clearInterval(intervalID)
}
}
const intervalID = setInterval(() => f(intervalID), 1000)
Your intervalID
is not an argument passed to f
, but if you just remove the argument it will work because the intervalID
is lexically scoped so that it's available inside f
.
let counter = 0;
const f = () => {
console.log("Hello World");
counter += 1
console.log(intervalID)
if (counter ==5){
console.log("Done")
clearInterval(intervalID)
}
}
const intervalID = setInterval(f, 1000)
OR passing in the intervalID
is also fine:
let counter = 0;
const f = (intervalID) => {
console.log("Hello World");
counter += 1
console.log(intervalID)
if (counter ==5){
console.log("Done")
clearInterval(intervalID)
}
}
const intervalID = setInterval(() => f(intervalID), 1000)
answered Jan 3 at 1:18


AdamAdam
28.7k94464
28.7k94464
Thanks a lot, the lexical scoping in JavaScript is really different. I don't even understand how is that possible! Can you explain a little bit more about it?
– Harshdeep Gupta
Jan 3 at 1:40
add a comment |
Thanks a lot, the lexical scoping in JavaScript is really different. I don't even understand how is that possible! Can you explain a little bit more about it?
– Harshdeep Gupta
Jan 3 at 1:40
Thanks a lot, the lexical scoping in JavaScript is really different. I don't even understand how is that possible! Can you explain a little bit more about it?
– Harshdeep Gupta
Jan 3 at 1:40
Thanks a lot, the lexical scoping in JavaScript is really different. I don't even understand how is that possible! Can you explain a little bit more about it?
– Harshdeep Gupta
Jan 3 at 1:40
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f54015182%2fjavascript-scoping-rules-how-to-use-clearinterval-inside-a-callback%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Remove the
intervalID
parameter. The first parameter tosetInterval
isA function to be executed every delay milliseconds. The function is not passed any parameters, and no return value is expected.
– CertainPerformance
Jan 3 at 1:18