Nur fügte hinzu , dass , wenn Sie versuchen , etwas hinzuzufügen zu definieren, der bereits erklärt hat, dann ist dies der Weg ist , typsicher , dies zu tun, die auch schützt vor Buggy - for inImplementierungen.
export const augment = <U extends (string|symbol), T extends {[key :string] :any}>(
type :new (...args :any[]) => T,
name :U,
value :U extends string ? T[U] : any
) => {
Object.defineProperty(type.prototype, name, {writable:true, enumerable:false, value});
};
Welche kann sicher POLYfill verwendet werden. Beispiel
//IE doesn't have NodeList.forEach()
if (!NodeList.prototype.forEach) {
//this errors, we forgot about index & thisArg!
const broken = function(this :NodeList, func :(node :Node, list :NodeList) => void) {
for (const node of this) {
func(node, this);
}
};
augment(NodeList, 'forEach', broken);
//better!
const fixed = function(this :NodeList, func :(node :Node, index :number, list :NodeList) => void, thisArg :any) {
let index = 0;
for (const node of this) {
func.call(thisArg, node, index++, this);
}
};
augment(NodeList, 'forEach', fixed);
}
Leider kann es nicht Ihre Symbole aufgrund einer typecheck Einschränkung in der aktuellen TS , und es wird bei Ihnen nicht schreien , wenn die Zeichenfolge keine Definition überein aus irgendeinem Grund, ich werde den Fehler melden , nachdem er , ob sie sind bereits bewusst.