Return 与参数相同的对象
Return same object as argument
这可能是一个反模式,但我想 return 同一个对象作为参数,在这种情况下是这样的:
const handleConnection = (s: net.Socket): net.Socket => {
s.pipe(createParser()).on('data', (d: any) => {
log.info(chalk.green.underline('dygrep server response:'));
if (d && d.lastMessage) {
process.stdout.write(prompt);
}
});
return s;
};
所以理想的做法是做这样的事情:
const handleConnection = (s: net.Socket): s => {
s.pipe(createParser()).on('data', (d: any) => {
log.info(chalk.green.underline('dygrep server response:'));
if (d && d.lastMessage) {
process.stdout.write(prompt);
}
});
return s;
};
但是是的,这不太正确 - 我如何告诉 TypeScript 我正在 return 参数之一?
how do I tell TypeScript that I am returning one of the arguments
泛型。约束是 return 与参数相同,例如
function handleConnection<T extends net.Socket>(arg:T):T{}
此处作为 arg 传入的内容就是 returned 的内容。
这可能是一个反模式,但我想 return 同一个对象作为参数,在这种情况下是这样的:
const handleConnection = (s: net.Socket): net.Socket => {
s.pipe(createParser()).on('data', (d: any) => {
log.info(chalk.green.underline('dygrep server response:'));
if (d && d.lastMessage) {
process.stdout.write(prompt);
}
});
return s;
};
所以理想的做法是做这样的事情:
const handleConnection = (s: net.Socket): s => {
s.pipe(createParser()).on('data', (d: any) => {
log.info(chalk.green.underline('dygrep server response:'));
if (d && d.lastMessage) {
process.stdout.write(prompt);
}
});
return s;
};
但是是的,这不太正确 - 我如何告诉 TypeScript 我正在 return 参数之一?
how do I tell TypeScript that I am returning one of the arguments
泛型。约束是 return 与参数相同,例如
function handleConnection<T extends net.Socket>(arg:T):T{}
此处作为 arg 传入的内容就是 returned 的内容。