Monday, June 3, 2024
 Popular · Latest · Hot · Upcoming
177
rated 0 times [  181] [ 4]  / answers: 1 / hits: 32515  / 12 Years ago, tue, august 21, 2012, 12:00:00

Consider this simple code:



use strict;

var obj = {
f: function() {
this.prop = 'value';
g.bind( this )();
}
};

function g() {
console.log( this.prop );
}


If I try to validate this code, jshint gives me the error Possible strict violation. where I call console.log( this.prop );. This is because this is undefined in strict mode in a function.



But I'm binding this function before calling it, so this is the correct object.



I'm using this design pattern to avoid cluttering the main object. Passing the properties in the parameters will also clutter the function, so I refuse to do this. Besides, this is exactly what bind is for.



Is there a way for JSHint to let me do this?


More From » jshint

 Answers
5

It is extremely hard to detect this case without running the code. You can use option validthis to suppress this warning:



use strict;

var obj = {
f: function() {
this.prop = 'value';
g.bind( this )();
}
};

function g() {
/*jshint validthis:true */
console.log( this.prop );
}


It is to be noted that jshint comments are function scoped. So the comment will work for the function g and its inner functions, not just the next line.


[#83505] Monday, August 20, 2012, 12 Years  [reply] [flag answer]
Only authorized users can answer the question. Please sign in first, or register a free account.
zachariaho

Total Points: 34
Total Questions: 87
Total Answers: 100

Location: England
Member since Tue, Sep 8, 2020
4 Years ago
;