5

我正在尝试编写一个使用 sendgrid 的打字稿应用程序,但与其他定义不同,我从中得到typings的定义让typings install sendgrid --ambient我有些头疼:

我能够像这样实例化客户端:

import * as sendgrid from 'sendgrid';
import Email = Sendgrid.Email;
import Instance = Sendgrid.Instance;
...
private client: Instance;
...
this.client = sendgrid(user, key);

然后在代码的后面我试图发送一封电子邮件,这就是为什么 ts 迫使我首先导入电子邮件界面。

var email = new Email();
...
this.client.send(email, (err, data) => {
        if (err) {
            throw err;
        }
    });

tslint 不会抛出任何错误,但是当我构建和运行程序(或只是我的测试)时,我得到了这个:

摩卡炸了!ReferenceError:Sendgrid 未在 Object 中定义。(/Users/chrismatic/codingprojects/weview/weview-node/build/server/components/mail/clients/sendgrid.js:4:13)

有没有人可以展示的工作实现,或者我必须编写自己的界面?在此先感谢您的帮助

编辑:

生成的 js 文件如下所示:

var sendgrid = require('sendgrid');
var Email = Sendgrid.Email;

如果我取消“Sendgrid”的大写,那么错误就会消失,但我不能在 ts 文件中这样做

4

1 回答 1

11

这应该让您了解如何使用 SendGrid 的打字稿定义。

import * as SendGrid from 'sendgrid';

export class SendGridMail extends SendGrid.mail.Mail {}
export class SendGridEmail extends SendGrid.mail.Email {}
export class SendGridContent extends SendGrid.mail.Content {}

export class SendGridService {
  private sendGrid;

  constructor(private sendgridApiKey: string) {
    this.sendGrid = SendGrid(sendgridApiKey);

  }

  send(mail: SendGridMail): Promise<any> {

    let request = this.sendGrid.emptyRequest({
      method: 'POST',
      path: '/v3/mail/send',
      body: mail.toJSON()
    });

    return this.sendGrid.API(request);
  }

}

这是我如何使用上面的类:

let mail = new SendGridMail(
      new SendGridEmail('from@example.com'),
      'Sending with SendGrid is Fun',
      new SendGridEmail('to@example.com'),
      new SendGridContent('text/plain', 'Email sent to to@example.com'));


return this.sendgridService.send(mail);
于 2017-01-19T22:33:26.270 回答