Search Terms
jsdoc, interface
I found #16142 which was closed by the reporter, and never reopened even though some other people suggested it.
Suggestion
JSDoc has a way to declare interfaces, through @interface, @function (and then @implements on the class). It would be great if tsc could support them (defining a TS interface based on that info).
Use Cases
JSDoc interfaces are useful to define interfaces implemented by multiple classes, that are then used based on this interface. This is part of JSDoc, but currently unsupported by tsc.
Examples
/**
* @interface Metric
*/
/**
* @function
* @name Metric#getName
* @returns {string}
*/
/**
* @function
* @name Metric#compute
* @param context
* @param [extra]
* @returns {Promise<object>}
*/
/**
* @constructor
* @implements {Metric}
*/
function ActivityScoreMetric () {
// [REDACTED]
}
ActivityScoreMetric.prototype = {
compute: function (context, extra) {
// [REDACTED]
},
getName: function () {
return 'activity_score'
}
}
// Other implementations go there
// Later code deals with `Array<Metric>` for some variables
Checklist
My suggestion meets these guidelines:
Search Terms
jsdoc, interface
I found #16142 which was closed by the reporter, and never reopened even though some other people suggested it.
Suggestion
JSDoc has a way to declare interfaces, through
@interface,@function(and then@implementson the class). It would be great if tsc could support them (defining a TS interface based on that info).Use Cases
JSDoc interfaces are useful to define interfaces implemented by multiple classes, that are then used based on this interface. This is part of JSDoc, but currently unsupported by tsc.
Examples
Checklist
My suggestion meets these guidelines: