From fceea4aa3e582dd05895a3fd9d0287fbb3165055 Mon Sep 17 00:00:00 2001 From: yutent Date: Wed, 30 Aug 2023 14:50:08 +0800 Subject: [PATCH] =?UTF-8?q?=E6=B7=BB=E5=8A=A0=20Entry?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Entry.md | 84 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 84 insertions(+) create mode 100644 Entry.md diff --git a/Entry.md b/Entry.md new file mode 100644 index 0000000..b87ff64 --- /dev/null +++ b/Entry.md @@ -0,0 +1,84 @@ +## 入口文件配置 + +我们先来看一下脚手架默认生成的代码。 + +```js +import Five from '@gm5/core' + +const app = new Five() + +// 可开启session支持 +// app.set({ session: { enabled: true, type: 'redis' } }) + +// 可开启模板引擎的支持 +// app.set({ views: { enabled: true, dir: './views' } }) + +// 预加载应用, 这一步是必须的, 且需要在listen方法前调用 +app.preload('./apps/') + +// 中间件示例 +// app.use((req, res, next) => { +// if (req.method !== 'GET') { +// res.error('', 401) +// } +// next() +// }) + +// 安装拓展包, 可以应用中通过 this.context.$$log调用到, +// 在中间件, 或后面的其他拓展包中, 可以直接 this.$$log 调用 +// app.install({ +// name: 'log', +// install: function() { +// return new Logs('run_time.log', './data/logs/') +// } +// }) + +app.listen(3000) +``` + +可以看出, 框架从 实例化 到 启动, 只需要调用2个方法即可, 一是 预加载应用目录, 二是设置端口号。 + +接下来, 我们看一下框架实例对外暴露的几个方法。 + ++ `.set(obj)` + > 这是一个设置框架配置的方法, 传入一个对象, 会自动合并配置, 支持多次调用这个方法。 + > 但要注意的是, 配置合并只支持合并2层, 第3层开始, 全直接替换为最新传入的值。 + ++ `.get(key)` + > 读取配置, 只支持传入第1级的key值, 不支持直接读取子属性。 + ++ `.use(middleWare)` + > 使用中间件的方法, 传入一个函数, 该函数会在发生http访问时被触发执行, 执行的顺序是调用use方法的顺序。 + > 函数的`this`指向当前的框架实例 + > 函数执行时, 会传入3个参数, 依次是 `request, response, next`; + > 前面2个分别是请求对象和响应对象, 这2个对象的具体功能, 在后面的章节中介绍; 第3个参数是一个函数, 在处理完自己的逻辑时, 必须调用该方法。 + ++ `.install(obj[, arg])` + > 安装拓展包的方法, 传入一个对象,对象中必须包含有2个字段, `name, install`。 + > name是安装包的名字,该名字决定了安装后如何使用。 + > install是一个函数, 安装时被立即被调用, 且在启动http服务之前, 意味着该拓展包不能调用到中间件中的任何内容, 也没有request, response。 + > install函数的`this`, 指向的是当前框架实例, 默认没有参数传入, 除非安装的时候有带参数。 + ++ `.preload(dir)` + > 预加载应用目录, 这个没啥可说的了, 唯一要注意的是, 必须在listen方法之前调用。 + ++ `.listen(port)` + > 配置端口, 同时启动http服务。 + + + + +---- + +上一节: [⟪快速上手⟫](https://github.com/bytedo/gmf.core/wiki/Quickstart) + +下一节: [⟪默认配置⟫](https://github.com/bytedo/gmf.core/wiki/Config) + + + + + + + + +