I've got the following class in TypeScript:
class CallbackTest
{
public myCallback;
public doWork(): void
{
//doing some work...
this.myCallback(); //calling callback
}
}
I am using the class like this:
var test = new CallbackTest();
test.myCallback = () => alert("done");
test.doWork();
The code works, so it displays a messagebox as expected.
My question is: Is there any type I can provide for my class field myCallback
? Right now, the public field myCallback
is of type any
as shown above. How can I define the method signature of the callback? Or can I just set the type to some kind of callback-type? Or can I do nether of these? Do I have to use any
(implicit/explicit)?
I tried something like this, but it did not work (compile-time error):
public myCallback: ();
// or:
public myCallback: function;
I couldn't find any explanation to this online, so I hope you can help me.
To go one step further, you could declare a type pointer to a function signature like:
and use it like this:
I just found something in the TypeScript language specification, it's fairly easy. I was pretty close.
the syntax is the following:
In my example, it would be
You can declare a new type:
Update.
The
declare
keyword is not necessary. It should be used in the .d.ts files or in similar cases.Here is an example - accepting no parameters and returning nothing.
If you want to accept a parameter, you can add that too:
And if you want to return a value, you can add that also:
If you want a generic function you can use the following. Although it doesn't seem to be documented anywhere.
I came across the same error when trying to add the callback to an event listener. Strangely, setting the callback type to EventListener solved it. It looks more elegant than defining a whole function signature as a type, but I'm not sure if this is the correct way to do this.