解决nodejs使用apidoc问题:Cannot read property 'Filter...' of undefined

apidoc是什么?

apidoc 是一个根据源代码中api注解创建api文档的工具,轻便易用。

问题背景

  • 现象:nodejs中使用apidoc在控制台报如下错误:
require.min.js:19 TypeError: Cannot read property 'Filter...' of undefined
    at Object.__ (locale.js?v=1579071667889:35)
    at Object.<anonymous> (handlebars_helper.js?v=1579071667889:43)
    at Object.eval [as main] (eval at createFunctionContext (handlebars.min.js?v=1579071667889:28), <anonymous>:6:97)
    at c (handlebars.min.js?v=1579071667889:27)
    at d (handlebars.min.js?v=1579071667889:27)
    at e (handlebars.min.js?v=1579071667889:28)
    at main.js:295
    at Object.execCb (require.min.js:30)
    at ea.check (require.min.js:18)
    at ea.<anonymous> (require.min.js:23)

页面显示为空白:


错误截图
  • 软件环境:
    • apidoc 版本:0.19.1
    • 操作系统 macOS 10.14.6
    • Google chrome 版本 79.0.3945.117(正式版本)
    • node v10.16.3
  • 测试源代码
const Koa = require('koa');
const util = require('util');
const app = new Koa();
const helper = require('./helper');

let logger = helper.getLogger('logTest');

const router = require('koa-router')();

const handler = async (ctx, next) => {
    try {
        console.info("==>handler");
        await next();
        console.info("<==handler");
    } catch (e) {
        console.info('e.err:', e.err);
        console.info('e.status:', e.status);
        ctx.response.statusCode = e.status || e.err || 500;
        ctx.response.body = 'errrrrrrrrr';
        // console.error("error::", e);
        // console.error("error::", e.toString());
        // console.error("error::", e.toLocaleString());
        // console.error("error::", e.status);
        // console.error("error::", typeof e);
        // console.error("error::", e.valueOf());
        // console.error('err msg:', e.message);
        console.info("1<==handler");
        // ctx.app.emit('error', e, ctx)
        console.log(e.message === 'file_not_found');
        ctx.app.emit(e.message, new Error("log file can't be found"), ctx);
    }
};

app.use(handler);


/**
 * @api {post} /api/User/register 用户注册
 * @apiDescription 用户注册
 * @apiName Register
 * @apiGroup User
 * @apiParam {string} name 用户名
 * @apiParam {string} password 密码
 * @apiVersion 1.0.0
 */
app.use(router.get('/test', async ctx => {
    console.log("test log");
    ctx.throw(new Error(util.format('file_not_found:%s', 'asdfasdf')));
}).routes());

app.listen(3000);
console.log("ready for service");

app.on('file_not_found', (err, ctx) => {
    // console.error("file not found error:", err, ctx);
    // logger.error("file not found error: %s, ctx:%s", err, ctx);
    logger.error("err:", err);
    logger.info("--============================");
    logger.error("%s, ctx:%j", err.stack, ctx);
    // console.error('err stack:', err.stack);
});
  • 使用到的package.json
{
  "name": "koa-demos",
  "version": "1.0.0",
  "description": "a collection of simple demos of Koa",
  "scripts": {
    "dev": "cross-env NODE_ENV=dev nodemon demos/test/logtest.js",
    "prod": "cross-env NODE_ENV=prod node demos/test/logtest.js",
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "apidoc": {
    "template": {
        "forceLanguage": "zh-cn"
    },
    "title": "apiDoc在浏览器中的标题",
    "url": "api.github.com/v1"
  },
  "keywords": [
    "Koa",
    "Node"
  ],
  "author": "Li Yi",
  "dependencies": {
    "cross-env": "^6.0.3",
    "express-validator": "^6.3.0",
    "fs.promised": "^3.0.0",
    "koa": "^2.3.0",
    "koa-body": "^2.3.0",
    "koa-bodyparser": "^4.2.1",
    "koa-compose": "^4.0.0",
    "koa-parameter": "^3.0.1",
    "koa-route": "^3.2.0",
    "koa-router": "^7.4.0",
    "koa-schema": "0.0.1",
    "koa-static": "^4.0.1",
    "log4js": "^6.1.0"
  },
  "devDependencies": {
    "apidoc": "^0.19.1",
    "jsdoc": "^3.6.3"
  }
}
  • 运行的命令
// -i demos/test是测试文件所在的目录
// -f ".*\\.js$" 是用来指定要生成api的文件格式的
// -o ./apidoc是用来指定生成文件的目录的
 apidoc -i demos/test -f ".*\\.js$" -o ./apidoc

原因

在0.19.1版本中没有zh-cn这个编码了,得设置成为zh_cn。
之所以会设置成为这个错误的编码是因为在这篇博客中看到的教程设置的,现在版本迭代之后,zh-cn已经不能用了。
参见官方现有的locales

经验教训

  • 能看官网教程的时候还是尽量看官网的,毕竟网上散落的教程有可能过时了,但是官网的总会是最新的。。
  • 大家在博客中写教程的时候,尽量带上软件的版本号信息,环境信息,不然容易误导人
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,843评论 6 502
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,538评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,187评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,264评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,289评论 6 390
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,231评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,116评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,945评论 0 275
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,367评论 1 313
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,581评论 2 333
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,754评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,458评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,068评论 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,692评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,842评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,797评论 2 369
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,654评论 2 354

推荐阅读更多精彩内容

  • 前端和后端注释文档生成 前端和后端的 函数及api 说明文档生成总结,持续更新中 by Qzx 参考网址 jsD...
    流云012阅读 11,969评论 0 1
  • 寒彻残冬雾泛浑,远街近道罕行人。 暗云有意难留雪,深院无风不扫尘。 过客经心严盖脸,家亲依暖紧关门。 老翁所乐知何...
    sx老鱼阅读 170评论 0 0
  • 当一个人获得另一个人的赞美时,他便感觉获得了社会支持,从而增强了自我价值,变得自信、自尊,获得一种积极向上的动力,...
    青山忆旧阅读 128评论 0 1
  • 那一年我即将升入初三。因为基础不佳,初二增加了一门物理,老师的节奏又快,渐渐地我越来越吃不消,干脆偃旗息鼓...
    花房姑娘1987阅读 266评论 0 0
  • 在我小儿子很小的时候,有一次我因为跟先生通电话有些不愉快,心情莫名的不好,没有买菜也没有煮饭,天都黑了还躺在床上不...
    玉米婶阅读 11,320评论 133 185