How to access 'this' keyword inside of static method in react native?
I am not able to access 'this' keyword in my static method in react- native, when I try to access it, it's thrown me error like 'this.setState not a function'.
Here is my code.
static getShiftStatus = () =>{
//for check shift start or not
Usermodal.getShiftStatus((isStatus) =>{
this.setState({isShiftStart: isStatus}) //error occure here.
console.log(a.state.isShiftStart)
})
}
javascript
add a comment |
I am not able to access 'this' keyword in my static method in react- native, when I try to access it, it's thrown me error like 'this.setState not a function'.
Here is my code.
static getShiftStatus = () =>{
//for check shift start or not
Usermodal.getShiftStatus((isStatus) =>{
this.setState({isShiftStart: isStatus}) //error occure here.
console.log(a.state.isShiftStart)
})
}
javascript
2
Static methods aren't called on instances of the class, so if you just remove thestatickeyword it should work as expected.
– Tholle
Nov 21 '18 at 8:39
Bind the method to the instance in the constructor?
– evolutionxbox
Nov 21 '18 at 8:39
add a comment |
I am not able to access 'this' keyword in my static method in react- native, when I try to access it, it's thrown me error like 'this.setState not a function'.
Here is my code.
static getShiftStatus = () =>{
//for check shift start or not
Usermodal.getShiftStatus((isStatus) =>{
this.setState({isShiftStart: isStatus}) //error occure here.
console.log(a.state.isShiftStart)
})
}
javascript
I am not able to access 'this' keyword in my static method in react- native, when I try to access it, it's thrown me error like 'this.setState not a function'.
Here is my code.
static getShiftStatus = () =>{
//for check shift start or not
Usermodal.getShiftStatus((isStatus) =>{
this.setState({isShiftStart: isStatus}) //error occure here.
console.log(a.state.isShiftStart)
})
}
javascript
javascript
edited Nov 21 '18 at 8:44
Aniruddh Parihar
2,16911027
2,16911027
asked Nov 21 '18 at 8:34
JaydipJaydip
1,098817
1,098817
2
Static methods aren't called on instances of the class, so if you just remove thestatickeyword it should work as expected.
– Tholle
Nov 21 '18 at 8:39
Bind the method to the instance in the constructor?
– evolutionxbox
Nov 21 '18 at 8:39
add a comment |
2
Static methods aren't called on instances of the class, so if you just remove thestatickeyword it should work as expected.
– Tholle
Nov 21 '18 at 8:39
Bind the method to the instance in the constructor?
– evolutionxbox
Nov 21 '18 at 8:39
2
2
Static methods aren't called on instances of the class, so if you just remove the
static keyword it should work as expected.– Tholle
Nov 21 '18 at 8:39
Static methods aren't called on instances of the class, so if you just remove the
static keyword it should work as expected.– Tholle
Nov 21 '18 at 8:39
Bind the method to the instance in the constructor?
– evolutionxbox
Nov 21 '18 at 8:39
Bind the method to the instance in the constructor?
– evolutionxbox
Nov 21 '18 at 8:39
add a comment |
1 Answer
1
active
oldest
votes
this in the inner function points to something else.
You need to capture the this from the outside function.
static getShiftStatus = () =>{
var that = this; // capture here
Usermodal.getShiftStatus((isStatus) =>{
that.setState({isShiftStart: isStatus}) // use it here
console.log(a.state.isShiftStart)
})
}
But the inner function is an arrow function, so doesn't it use thethisvalue from its containing context?
– nnnnnn
Nov 21 '18 at 8:50
it's not work for me @Ahmad
– Jaydip
Nov 21 '18 at 8:59
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%2f53408021%2fhow-to-access-this-keyword-inside-of-static-method-in-react-native%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
this in the inner function points to something else.
You need to capture the this from the outside function.
static getShiftStatus = () =>{
var that = this; // capture here
Usermodal.getShiftStatus((isStatus) =>{
that.setState({isShiftStart: isStatus}) // use it here
console.log(a.state.isShiftStart)
})
}
But the inner function is an arrow function, so doesn't it use thethisvalue from its containing context?
– nnnnnn
Nov 21 '18 at 8:50
it's not work for me @Ahmad
– Jaydip
Nov 21 '18 at 8:59
add a comment |
this in the inner function points to something else.
You need to capture the this from the outside function.
static getShiftStatus = () =>{
var that = this; // capture here
Usermodal.getShiftStatus((isStatus) =>{
that.setState({isShiftStart: isStatus}) // use it here
console.log(a.state.isShiftStart)
})
}
But the inner function is an arrow function, so doesn't it use thethisvalue from its containing context?
– nnnnnn
Nov 21 '18 at 8:50
it's not work for me @Ahmad
– Jaydip
Nov 21 '18 at 8:59
add a comment |
this in the inner function points to something else.
You need to capture the this from the outside function.
static getShiftStatus = () =>{
var that = this; // capture here
Usermodal.getShiftStatus((isStatus) =>{
that.setState({isShiftStart: isStatus}) // use it here
console.log(a.state.isShiftStart)
})
}
this in the inner function points to something else.
You need to capture the this from the outside function.
static getShiftStatus = () =>{
var that = this; // capture here
Usermodal.getShiftStatus((isStatus) =>{
that.setState({isShiftStart: isStatus}) // use it here
console.log(a.state.isShiftStart)
})
}
answered Nov 21 '18 at 8:40
AhmadAhmad
8,21543563
8,21543563
But the inner function is an arrow function, so doesn't it use thethisvalue from its containing context?
– nnnnnn
Nov 21 '18 at 8:50
it's not work for me @Ahmad
– Jaydip
Nov 21 '18 at 8:59
add a comment |
But the inner function is an arrow function, so doesn't it use thethisvalue from its containing context?
– nnnnnn
Nov 21 '18 at 8:50
it's not work for me @Ahmad
– Jaydip
Nov 21 '18 at 8:59
But the inner function is an arrow function, so doesn't it use the
this value from its containing context?– nnnnnn
Nov 21 '18 at 8:50
But the inner function is an arrow function, so doesn't it use the
this value from its containing context?– nnnnnn
Nov 21 '18 at 8:50
it's not work for me @Ahmad
– Jaydip
Nov 21 '18 at 8:59
it's not work for me @Ahmad
– Jaydip
Nov 21 '18 at 8:59
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%2f53408021%2fhow-to-access-this-keyword-inside-of-static-method-in-react-native%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
2
Static methods aren't called on instances of the class, so if you just remove the
statickeyword it should work as expected.– Tholle
Nov 21 '18 at 8:39
Bind the method to the instance in the constructor?
– evolutionxbox
Nov 21 '18 at 8:39