当前位置: 代码网 > it编程>编程语言>Javascript > TypeScript开发HapiJS应用详解

TypeScript开发HapiJS应用详解

2024年05月15日 Javascript 我要评论
初始化npm项目yarn init添加依赖yarn add hapi添加开发依赖要在开发中使用typescrip,同时至少需要有一个工具,可以一直监听项目文件的变更,并实时的将变更更新至启动的服务中,

初始化 npm 项目

yarn init

添加依赖

yarn add hapi

添加开发依赖

要在开发中使用 typescrip,同时至少需要有一个工具,可以一直监听项目文件的变更,并实时的将变更更新至启动的服务中,我选择使用 nodemon,首先添加以下几个开发依赖

yarn add typescript -d
yarn add nodemon -d

接下来,我们需要为 node 与 hapi 安装类型定义库:

yarn add @types/node -d
yarn add @types/hapi -d

安装完成之后, package.json 文件看起来像下面这样的:

{
  "name": "hapiserver",
  "version": "0.0.1",
  "description": "api server",
  "main": "index.js",
  "author": "your name",
  "license": "mit",
  "dependencies": {
    "hapi": "^18.1.0"
  },
  "devdependencies": {
    "@types/hapi": "^18.0.2",
    "@types/node": "^12.0.2",
    "nodemon": "^1.19.0",
    "typescript": "^3.4.5"
  }
}

 注意:你的 dependencies 与 devdependencies 配置中,版本号可能与我的不同。

配置 typescript

设计项目文件目录结构

在项目的根目录下,创建一个名为 src 的目录,用于包含系统的所有源代码文件,接着,创建一个名为 dist 的目录,用于保存由 typescript 编译后的 javascript 文件。

注意:文件结构并不是强制的,你可以完全按照自己的习惯和规范来进行

.
├── dist
├── node_modules
├── package.json
├── src
└── yarn.lock

tsconfig.json

typescript 会查询名为 tsconfig.json 的配置文件来查找项目的入口文件以及编译设置,关于它的详细使用说明,可以从 https://www.typescriptlang.org/docs/handbook/tsconfig-json.html 查阅,在这里,我们先填入以下内容:

{
  "compileroptions": {
    "outdir": "./dist",
    "allowjs": false,
    "target": "es6",
    "sourcemap": true,
    "module": "commonjs",
    "moduleresolution": "node"
  },
  "include": ["./src/**/*"],
  "exclude": ["node_modules"]
}

在 tsconfig.json 文件中,我们定义了 outdir 的值为 ./dist,它告诉编译器,编译后的输出目录为 ./dist 文件夹,现在可以直接在项目根目录执行以下代码,即可编译 src 目录下的 typescript 代码至 dist 目录下的 javascript 文件了。

node_modules/typescript/bin/tsc

用 typescript 开发 hapi 服务应用

在 src 目录下,创建一个名为 server.ts 的文件,内容如下:

import * as hapi from "hapi";
// 创建一个服务器,监听 `localhost` 上的 `8000` 商品
const server: hapi.server = new hapi.server({
  host: "localhost",
  port: 8000
});
// 添加路由
server.route({
  method: "get",
  path: "/hello",
  handler: function(request, h) {
    return "hello! typescript!";
  }
});
// 启动服务
async function start() {
  try {
    await server.start();
  } catch (err) {
    console.log(err);
    process.exit(1);
  }
  console.log("server running at:", server.info.uri);
}
// 不要忘记启动服务
start();

由于我们的代码是由 typescript 写的,所以现在还没有办法直接运行,需要先将其编译为 javascript 代码之后再运行:

使用下面的命令编译代码:

node_modules/typescript/bin/tsc

编译完成之后,将得到下面这样的两个文件:

dist
├── server.js
└── server.js.map

此时,执行下面的代码,启动服务:

node dist/server.js

启动成功之后,终端将显示:

server running at: http://localhost:8000

使用 curl 测试一下我们的服务:

$ curl -i http://localhost:8000/hello
http/1.1 200 ok
content-type: text/html; charset=utf-8
cache-control: no-cache
content-length: 18
accept-ranges: bytes
date: fri, 17 may 2019 01:58:50 gmt
connection: keep-alive
hello! typescript!

已经启动成功了。

完成所有配置

我们总不能每改一次代码,都手工执行一次编译,再重新启动服务,可以在 package.json 中添加两个命令:

{
  ...
  "scripts": {
    "start": "./node_modules/nodemon/bin/nodemon.js -e ts  --exec \"yarn run compile\"",
    "compile": "tsc && node ./dist/server.js"
  },
  ...
}

现在,只需要在项目根目录下执行以下代码,即可启动一个实时编译代码并自动重新服务的开发环境了:

yarn start

它的作用是:nodemon 启动一个服务,监听文件的变更,当有任何文件变更之后,执行 yarn run compile 命令(即执行:tsc && node ./dist/server.js,以重启服务。

以上就是typescript开发hapijs应用详解的详细内容,更多关于typescript开发hapijs 的资料请关注代码网其它相关文章!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com