簡體   English   中英

如何使用打字稿擴展表達對象?

[英]How to extend express object using typescript?

編譯打字稿項目時,沒有看到express import import {Request, Response} 現在,我嘗試使用require但不確定如何擴展express對象以及使用reqres 任何幫助將不勝感激。

索引

// import {Request, Response} from 'express';
import express = require('express');
import * as sdkStore from "../../common/sdk-store";


export function getInfo(req: Request, res: Response) {

    var app = sdkStore.getSdkInstance(req.body.client);
    app.Payment.Info(req.body, function (result) {
        res.send(result);
    });
}

我正在使用相同的策略來使用express模塊的RequestResponse

這就是我的做法(檢查getTemples方法的參數)-

打字稿

import * as express from "express";
import { Response as ApiResponse } from "../models/response.model";
import { TempleProvider } from "../providers/temple.provider";

export namespace TempleFacade {

    export function getTemples(req: express.Request, res: express.Response, next: express.NextFunction): void {
        let apiResponse: ApiResponse<any> = new ApiResponse();
        TempleProvider.getTemples()
            .then((response: Array<any>) => {
                apiResponse.data = response;
                res.json(apiResponse);
            })
            .catch((error: any) => {
                apiResponse.data = null;
                apiResponse.status = false;
                apiResponse.messages = error;
                res.json(apiResponse);
            });
    }
}

編譯的Javascript

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const response_model_1 = require("../models/response.model");
const temple_provider_1 = require("../providers/temple.provider");
var TempleFacade;
(function (TempleFacade) {
    function getTemples(req, res, next) {
        let apiResponse = new response_model_1.Response();
        temple_provider_1.TempleProvider.getTemples()
            .then((response) => {
            apiResponse.data = response;
            res.json(apiResponse);
        })
            .catch((error) => {
            apiResponse.data = null;
            apiResponse.status = false;
            apiResponse.messages = error;
            res.json(apiResponse);
        });
    }
    TempleFacade.getTemples = getTemples;
})(TempleFacade = exports.TempleFacade || (exports.TempleFacade = {}));
//# sourceMappingURL=temple.facade.js.map

我希望這有幫助 :)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM