解決nodejs使用apidoc問題:Cannot read property 'Filter...' of undefined

apidoc是什么窗怒?

apidoc 是一個(gè)根據(jù)源代碼中api注解創(chuàng)建api文檔的工具映跟,輕便易用蓄拣。

問題背景

  • 現(xiàn)象:nodejs中使用apidoc在控制臺(tái)報(bào)如下錯(cuò)誤:
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)

頁(yè)面顯示為空白:


錯(cuò)誤截圖
  • 軟件環(huán)境:
    • apidoc 版本:0.19.1
    • 操作系統(tǒng) macOS 10.14.6
    • Google chrome 版本 79.0.3945.117(正式版本)
    • node v10.16.3
  • 測(cè)試源代碼
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 用戶注冊(cè)
 * @apiDescription 用戶注冊(cè)
 * @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在瀏覽器中的標(biāo)題",
    "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"
  }
}
  • 運(yùn)行的命令
// -i demos/test是測(cè)試文件所在的目錄
// -f ".*\\.js$" 是用來(lái)指定要生成api的文件格式的
// -o ./apidoc是用來(lái)指定生成文件的目錄的
 apidoc -i demos/test -f ".*\\.js$" -o ./apidoc

原因

在0.19.1版本中沒有zh-cn這個(gè)編碼了,得設(shè)置成為zh_cn努隙。
之所以會(huì)設(shè)置成為這個(gè)錯(cuò)誤的編碼是因?yàn)樵?a target="_blank">這篇博客中看到的教程設(shè)置的球恤,現(xiàn)在版本迭代之后,zh-cn已經(jīng)不能用了荸镊。
參見官方現(xiàn)有的locales

經(jīng)驗(yàn)教訓(xùn)

  • 能看官網(wǎng)教程的時(shí)候還是盡量看官網(wǎng)的咽斧,畢竟網(wǎng)上散落的教程有可能過時(shí)了,但是官網(wǎng)的總會(huì)是最新的躬存。张惹。
  • 大家在博客中寫教程的時(shí)候,盡量帶上軟件的版本號(hào)信息岭洲,環(huán)境信息宛逗,不然容易誤導(dǎo)人
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市盾剩,隨后出現(xiàn)的幾起案子雷激,更是在濱河造成了極大的恐慌,老刑警劉巖告私,帶你破解...
    沈念sama閱讀 212,542評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件屎暇,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡驻粟,警方通過查閱死者的電腦和手機(jī)恭垦,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,596評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)格嗅,“玉大人番挺,你說(shuō)我怎么就攤上這事⊥鸵矗” “怎么了玄柏?”我有些...
    開封第一講書人閱讀 158,021評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)贴铜。 經(jīng)常有香客問我粪摘,道長(zhǎng),這世上最難降的妖魔是什么绍坝? 我笑而不...
    開封第一講書人閱讀 56,682評(píng)論 1 284
  • 正文 為了忘掉前任徘意,我火速辦了婚禮,結(jié)果婚禮上轩褐,老公的妹妹穿的比我還像新娘椎咧。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,792評(píng)論 6 386
  • 文/花漫 我一把揭開白布勤讽。 她就那樣靜靜地躺著蟋座,像睡著了一般。 火紅的嫁衣襯著肌膚如雪脚牍。 梳的紋絲不亂的頭發(fā)上向臀,一...
    開封第一講書人閱讀 49,985評(píng)論 1 291
  • 那天,我揣著相機(jī)與錄音诸狭,去河邊找鬼券膀。 笑死,一個(gè)胖子當(dāng)著我的面吹牛驯遇,可吹牛的內(nèi)容都是我干的三娩。 我是一名探鬼主播,決...
    沈念sama閱讀 39,107評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼妹懒,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼雀监!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起眨唬,我...
    開封第一講書人閱讀 37,845評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤会前,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后匾竿,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體瓦宜,經(jīng)...
    沈念sama閱讀 44,299評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,612評(píng)論 2 327
  • 正文 我和宋清朗相戀三年岭妖,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了临庇。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,747評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡昵慌,死狀恐怖假夺,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情斋攀,我是刑警寧澤已卷,帶...
    沈念sama閱讀 34,441評(píng)論 4 333
  • 正文 年R本政府宣布,位于F島的核電站淳蔼,受9級(jí)特大地震影響侧蘸,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜鹉梨,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,072評(píng)論 3 317
  • 文/蒙蒙 一讳癌、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧存皂,春花似錦晌坤、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,828評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至猜憎,卻和暖如春娩怎,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背胰柑。 一陣腳步聲響...
    開封第一講書人閱讀 32,069評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工截亦, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人柬讨。 一個(gè)月前我還...
    沈念sama閱讀 46,545評(píng)論 2 362
  • 正文 我出身青樓崩瓤,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親踩官。 傳聞我的和親對(duì)象是個(gè)殘疾皇子却桶,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,658評(píng)論 2 350

推薦閱讀更多精彩內(nèi)容

  • 前端和后端注釋文檔生成 前端和后端的 函數(shù)及api 說(shuō)明文檔生成總結(jié),持續(xù)更新中 by Qzx 參考網(wǎng)址 jsD...
    流云012閱讀 11,956評(píng)論 0 1
  • 寒徹殘冬霧泛渾蔗牡,遠(yuǎn)街近道罕行人颖系。 暗云有意難留雪,深院無(wú)風(fēng)不掃塵辩越。 過客經(jīng)心嚴(yán)蓋臉嘁扼,家親依暖緊關(guān)門。 老翁所樂知何...
    sx老魚閱讀 170評(píng)論 0 0
  • 當(dāng)一個(gè)人獲得另一個(gè)人的贊美時(shí)黔攒,他便感覺獲得了社會(huì)支持趁啸,從而增強(qiáng)了自我價(jià)值,變得自信督惰、自尊不傅,獲得一種積極向上的動(dòng)力,...
    青山憶舊閱讀 126評(píng)論 0 1
  • 那一年我即將升入初三赏胚。因?yàn)榛A(chǔ)不佳蛤签,初二增加了一門物理,老師的節(jié)奏又快栅哀,漸漸地我越來(lái)越吃不消震肮,干脆偃旗息鼓...
    花房姑娘1987閱讀 263評(píng)論 0 0
  • 在我小兒子很小的時(shí)候,有一次我因?yàn)楦壬娫捰行┎挥淇炝羰埃那槟牟缓么辽危瑳]有買菜也沒有煮飯,天都黑了還躺在床上不...
    玉米嬸閱讀 11,309評(píng)論 133 185