1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
|
//// [classMemberInitializerWithLamdaScoping.ts]
declare var console: {
log(msg?: any): void;
};
class Test {
constructor(private field: string) {
}
messageHandler = () => {
var field = this.field;
console.log(field); // Using field here shouldnt be error
};
static field: number;
static staticMessageHandler = () => {
var field = Test.field;
console.log(field); // Using field here shouldnt be error
};
}
var field1: string;
class Test1 {
constructor(private field1: string) {
}
messageHandler = () => {
console.log(field1); // But this should be error as the field1 will resolve to var field1
// but since this code would be generated inside constructor, in generated js
// it would resolve to private field1 and thats not what user intended here.
};
static staticMessageHandler = () => {
console.log(field1); // This shouldnt be error as its a static property
};
}
//// [classMemberInitializerWithLamdaScoping.js]
var Test = (function () {
function Test(field) {
var _this = this;
this.field = field;
this.messageHandler = function () {
var field = _this.field;
console.log(field); // Using field here shouldnt be error
};
}
return Test;
}());
Test.staticMessageHandler = function () {
var field = Test.field;
console.log(field); // Using field here shouldnt be error
};
var field1;
var Test1 = (function () {
function Test1(field1) {
this.field1 = field1;
this.messageHandler = function () {
console.log(field1); // But this should be error as the field1 will resolve to var field1
// but since this code would be generated inside constructor, in generated js
// it would resolve to private field1 and thats not what user intended here.
};
}
return Test1;
}());
Test1.staticMessageHandler = function () {
console.log(field1); // This shouldnt be error as its a static property
};
|