Node.js开发中的那些旮旮角角 第一部

前戏

上一周是我到现公司来最忙碌的(最有意思的)一周了,为什么这么说呢?因为项目中需要提供服务端对用户病人信息的一个汇总并以email的形式分享信息的接口,在几天的时间里调研处理一套实施方案。我们服务端是Node.js实现的(其中的npm中有很多丰富的第三方库来解放你重新造轮子的尴尬)

配方

pug->html-pdf->pdf2png->s3->sendgrid

pug 中在phantom中字体无效的解决方案

在开发pug时遇到一个比较棘手的问题,设计定的字体在浏览器上是有效果的,但是通过Phantom.js(服务器端的 JavaScript API 的 WebKit)进行网页截图时,字体却都使用了默认字体,后来只有通过自定义字体文件才解决这个问题。

style.
        @font-face {
            font-family: CustomFont;
            src: url('./views/fonts/HelveticaNeue.otf');
        }


        .gender {
            display: inline;
            color: rgb(102, 102, 102);
            font-family: CustomFont;
        }

嗯,模板文件算是搞定了,接下来就是具体代码的实现了。

准备数据材料

要做某件事情肯定都会先把需要的材料先搞到手把!(感觉编程和现实生活中解决问题的思路很多都是想通的)

我是受到某人的启发说通过一个汇总链表查询,把N张表的数据都通过一个查询搞出来,最后把它变成View,也方便服务端的开发,我这么一听感觉是很有道理啊,那就做吧(我感觉我执行力好强☺)

在我们的系统有些表的设置是字段可以方便增加字段类型,但在查询时就必须要考虑行转列,或是列转行(这在我之前都是未知领域)

select patient_id, max(IF(contact_type = 'email',value,null)) as 'email', max(IF(contact_type = 'address',value,null)) as 'address', group_concat(case when contact_type='mobile' then contacts.value end) as 'mobiles'
  from contacts where contacts.is_deleted = 0 group by patient_id

max(IF(contact_type = 'email',value,null) 可以将列中符合contact_type='email' 的提出来单独作为一列;group_concat(case when contact_type='mobile' then contacts.value end) 则可以将多个类型的通过拼接放在一个单元格中。不过最后遇到一个问题,就是无法将多个mobile很好的区分出来。所以只好老实的在Node.js中分批的查询其中的数据。放一张截图,肯定能体会出我心中N多的XX马(留意下文件名)

Paste_Image.png

分批次取数据

先讲解下前提,customDiagnoses和patientDiagnoses表是1->N的关系。

const customDiagnoses = await Promise.all(
            patientDiagnoses.map(item =>
                CustomDiagnosis.findById(item.sourceId)
            )
)

Promise.all()是需要等待其中的所有的方法都完全处理完后再执行后面的语句

这里可以补充一个《如何把一个异步的方法搞成一个看似同步的方法》

    static async exportPDF(html, options, filePath) {
        const promise = new Promise((reslove, reject) => {
            const callback = (err, res) => {
                if (err) {
                    reject(err)
                    return
                }
                reslove(res)
            }
            pdf.create(html, options).toFile(filePath, callback)
        })
        return promise
    }

Promise顾名思义就是当你达成某种成就了,我就会帮你干某件事。
写一个Promise最有变化就是对callback的处理,其他的基本都跟这个差不多,使用Promise也很简单,直接在调用的地方前面加上一个await即可。

有人会问了为什么要写Promise啊?Node.js 不是都是有callback的吗?干嘛还要我多次一举?

起始也不完全都要把异步方法用Promise封装起来,但是if 你的一个方法中有N个异步的 && 根据上一个方法的结果来干下一件事 {
那么你的代码就会变成一个阶梯状,一层嵌套一层,不移维护也不易阅读
}

最后附上,我心情劳动后,上天也被感动,给力我一个超可爱的喵星人,也要感谢在开发过程支持和帮助我的某某人!!!

![IMG_0395.JPG](http://upload-images.jianshu.io/upload_images/1530185-d6cb759bb8687d07.JPG?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

下部预告,《测试达人带飞,让你装逼让你吹》

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

推荐阅读更多精彩内容