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 64 65 66 67 68 69 70 71 72 73 74 75 76 77
|
=== tests/cases/compiler/thisBinding2.ts ===
class C {
>C : C
x: number;
>x : number
constructor() {
this.x = (() => {
>this.x = (() => { var x = 1; return this.x; })() : number
>this.x : number
>this : this
>x : number
>(() => { var x = 1; return this.x; })() : number
>(() => { var x = 1; return this.x; }) : () => number
>() => { var x = 1; return this.x; } : () => number
var x = 1;
>x : number
>1 : 1
return this.x;
>this.x : number
>this : this
>x : number
})();
this.x = function() {
>this.x = function() { var x = 1; return this.x; }() : any
>this.x : number
>this : this
>x : number
>function() { var x = 1; return this.x; }() : any
>function() { var x = 1; return this.x; } : () => any
var x = 1;
>x : number
>1 : 1
return this.x;
>this.x : any
>this : any
>x : any
}();
}
}
declare function setTimeout(expression: any, msec?: number, language?: any): number;
>setTimeout : { (handler: TimerHandler, timeout?: number, ...arguments: any[]): number; (expression: any, msec?: number, language?: any): number; }
>expression : any
>msec : number
>language : any
var messenger = {
>messenger : { message: string; start: () => number; }
>{ message: "Hello World", start: function () { return setTimeout(() => { var x = this.message; }, 3000); }} : { message: string; start: () => number; }
message: "Hello World",
>message : string
>"Hello World" : "Hello World"
start: function () {
>start : () => number
>function () { return setTimeout(() => { var x = this.message; }, 3000); } : () => number
return setTimeout(() => { var x = this.message; }, 3000);
>setTimeout(() => { var x = this.message; }, 3000) : number
>setTimeout : { (handler: TimerHandler, timeout?: number, ...arguments: any[]): number; (expression: any, msec?: number, language?: any): number; }
>() => { var x = this.message; } : () => void
>x : string
>this.message : string
>this : { message: string; start: () => number; }
>message : string
>3000 : 3000
}
};
|