我试图将nodejs中的以下代码片段转换为typescript:How do I make Http Request in Nodejs

这是我的打字脚本代码:

import * as http from 'http';

export class HttpRequest{
url: string;
private path: string;
private host: string;
private args: Array<Array<string>>;

constructor(url: string, args?: string){
    this.url = url;
    this.processUrl(this.url);
    if(!!args){
        this.processArgs(args);
    }
    this.args = [];
}
private processUrl(url: string): void {
    let tld: number = url.lastIndexOf('.')
    let sep: number = url.indexOf('/', tld);
    this.host = url.slice(0, sep);
    this.path = url.slice(sep+1);
}
private processArgs(args: string): void {
    let sep: number = args.indexOf('&');
    if(sep < 0){
        return ;
    }
    let argpair: string = args.slice(0, sep);
    let apsep: number = argpair.indexOf('=');
    let k: string = argpair.slice(0, apsep);
    let v: string = argpair.slice(apsep+1);
    this.args.push([k,v]);
    this.processArgs(args.slice(sep+1));
}
private preparePath(): string {
    let path: string = `?`;
    this.args.forEach((arg: Array<string>, i: number): void => {
        let k: string = arg[0];
        let v: string = arg[1];
        path += k + '=' + v;
        if(i == this.args.length-1){
            return ;
        }
        path += '&';
    });
    return path;
}
public addArg(key: string, value: string): void {
    try{
        this.args.push([key,value]);
    } catch(err) {
        console.log(err);
    }
}
public addArgs(args: Array<Array<string>>): void {
    args.forEach((arg: Array<string>): void => {
        this.args.push(arg);
    });
}
public get(cb: (res: any) => any): void {
    let opts = {
        'host': this.host,
        'path': `/${this.path}/${this.preparePath()}`
    };
    http.request(opts, (r: http.IncomingMessage): void => {
        let data = '';
        r.on('data', (chunk: string): void => {
            console.log('Got chunk: ' + chunk);
            data += chunk;
        });
        r.on('end', (): void =>{
            console.log('Response has ended');
            console.log(data);
            cb(data);
        });
        r.on('error', (err): void => {
            console.log('Following error occured during request:\n');
            console.log(err);
        })
    }).end();
}
public test(): void {
    console.log(this.preparePath());
    console.log(`/${this.path}/${this.preparePath()}`);
}
}

以下是我的测试代码:

// Test httpRequest

import { HttpRequest } from './httpRequest';

const request = new HttpRequest('www.random.org/integers');
request.addArg('num', '1');
request.addArg('min', '1');
request.addArg('max', '50');
request.addArg('col', '1');
request.addArg('base', '10');
request.addArg('format', 'plain');
request.addArg('rnd', 'new');
request.test();
request.get((res: string): void => {
    console.log('Response received: ' + res);
});

如果这一切正常(我判断了Firefox上的链接,它返回一个纯文本随机数),我应该得到一个纯文本数字.然而,当我得到console.log()个回复时,我什么也得不到.我做错了什么?

推荐答案

尽管request-promise-native可能工作得很好,但Axios是在TypeScript中使用的更好 Select .它有自己的类型定义,总体上不太依赖于其他包.使用它的API很像Adrian提供的答案,但是有一些细微的区别.

const url: string = 'your-url.example';

try {
    const response = await axios.get(url);
} catch (exception) {
    process.stderr.write(`ERROR received from ${url}: ${exception}\n`);
}

显然,如果希望客户机处理异常,可以省略try/catch语句.

Typescript相关问答推荐

如何一般设置映射类型的值

通用默认值触发依赖通用约束变量的错误

如何在ts中使用函数重载推断参数类型

需要使用相同组件重新加载路由变更数据—React TSX

如何以Angular 形式显示验证错误消息

为什么T[数字]不也返回UNDEFINED?

如何在Vue中使用Enum作为传递属性的键类型?

从泛型类型引用推断的文本类型

为什么我在这个重载函数中需要`as any`?

如何在Angular 服务中制作同步方法?

创建一个TypeScrip对象并基于来自输入对象的约束定义其类型

三重融合视角与正交阵

如何使用angular15取消选中位于其他组件中的复选框

typescript如何从映射类型推断

如何使用useSearchParams保持状态

TypeScript:如何使用泛型和子类型创建泛型默认函数?

如何知道使用TypeScript时是否在临时工作流内运行

Typescript:是否将联合类型传递给重载函数?

如何从联合类型推断函数参数?

Typescript 和 Rust 中跨平台的位移数字不一致