我的NodeJS学习之路8(优化体验)

请关注专题:我的NodeJS学习之路(实践之路)

小弟初涉node领域,不足之处,还请多多指教!
欢迎Star、Fork:https://github.com/gefangshuai/ANodeBlog

本文主要介绍几个“好玩”的Middleware(中间件)来提升网站的用户体验。

Moment.js

Parse, validate, manipulate, and display dates in JavaScript.
正如官网的介绍,我觉得这货是一个全能的处理日期的中间件。

安装及使用:

npm install moment --save
var moment = require('moment');

格式化日期

  1. 格式化日期
moment().format('YYYY-MM-DD HH:mm:ss'); //2016-01-25 09:36:09
moment().format('YYYY [escaped] YYYY');  // 2016 escaped 2016
  1. 今天是星期几
moment().format('d'); //3 

换算相对时间

moment("20111031", "YYYYMMDD").fromNow(); // 4 年前
moment("20120620", "YYYYMMDD").fromNow(); // 4 年前
moment().startOf('day').fromNow();  // 10 小时前
moment().endOf('day').fromNow();  // 在 14 小时内
moment().startOf('hour').fromNow(); // 21 分钟前

在本例中的应用

本例中,首页的相对时间戳

Paste_Image.png

文章内的相对时间戳
Paste_Image.png

都是使用Momentjs实现的。

细心的朋友可以发现,Momentjs也提供了bower的安装包,所以直接可以在前台使用,但是我们并不推荐这样做,把处理放到前台会影响用户的体验。所以我们使用npm包放到后台去处理。

我们的模版是Handlebars,所以需要在系统中注册一个helper,命名为timeFromNow

timeFromNow: function (date) {    
    return moment(date).fromNow();
}

然后就可以这样使用了:

<span class="pull-right time-from-now">{{timeFromNow created_time}}</span>

更多Momentjs用法请参考官方文档

使用Gravatar中间件显示全球公认的头像

Gravatar英语Globally Recognized Avatar)是一项用于提供在全球范围内使用的头像服务。只要你在Gravatar的服务器上上传了你自己的头像,你便可以在其他任何支持Gravatar的博客、论坛等地方使用它。——转自wikipedia

玩过网站的童靴对这货应该不陌生,我第一次接触是从Wordpress开始的。只需要一个邮件账号,就可以建立你自己的全球公认头像。

在网站中集成它,我们用到了node-gravatar

安装及集成

npm install --save gravatar

使用:

var gravatar = require('gravatar');
gravatar.url(email, options, protocol);

参数说明:

  • email:注册gravatar服务的邮箱
  • options:参数,sizes指定头像大小;defaultd指定缺省头像;ratingr指定头像评级;

使用示例:

var gravatar = require('gravatar');
var url = gravatar.url('emerleite@gmail.com', {s: '200', r: 'pg', d: '404'});
//returns //www.gravatar.com/avatar/93e9084aa289b7f1f5e4ab6716a56c3b?s=200&r=pg&d=404
var unsecureUrl = gravatar.url('emerleite@gmail.com', {s: '100', r: 'x', d: 'retro'}, false);
//returns http://www.gravatar.com/avatar/93e9084aa289b7f1f5e4ab6716a56c3b?s=100&r=x&d=retro
var secureUrl = gravatar.url('emerleite@gmail.com', {s: '100', r: 'x', d: 'retro'}, true);
//returns https://s.gravatar.com/avatar/93e9084aa289b7f1f5e4ab6716a56c3b?s=100&r=x&d=retro

如何在国内正常使用

由于不可抗力,gravatar的服务器已经被墙了……

我们可以使用多说的服务来加速gravatar的请求。方法很简单,只需要将转换后的url信息中的www.gravatar.com替换为gravatar.duoshuo.com就可以了。

在本例中使用

为了能正确展示注册用户的头像信息,我们需要强制注册用户都填写email信息。

然后定义一个Handlebars helper

/**
 * 渲染全球通用头像
 * @param email
 * @returns {*}
 */
gravatar: function (email) {
    var url = gravatar.url(email, {s: '100', r: 'G', d: 'retro'});
    url = lodash.replace(url, 'www.gravatar.com', 'gravatar.duoshuo.com');
    return url;
}

这里用到了lodash,一个强大的Javascript工具包,后面会有介绍。

最后可以直接在模版页面中使用了:

<img src="{{gravatar session.user.email}}" class="img-circle" alt="User Image">

更多node-gravatar的知识请参考官方主页

集成Markdown编辑器并渲染显示

Markdown相比较传统的富文本编辑器,拥有便捷、快速、专注内容等特点,特别是作为一个程序员,使用markdown可以快速地将我们的代码片段记录下来,方便以后查看。(我们不是专业的写作者,所以对排版并不是非常严格)

在项目中集成Markdown,最简单的方法就是直接放一个textarea,然后后台通过remarkable进行渲染。
这里有一个Remarkable在线演示示例:https://jonschlinkert.github.io/remarkable/demo/

使用Remarkable

下面说一下详细的使用方法

为了能够支持代码高亮,我们还用到了另外一个中间件highlight

首先安装集成

npm install --save remarkable
npm install --save highlight

使用

var Remarkable = require('remarkable');
var hljs = require('highlight.js');
var md = function () {
    return new Remarkable('full', {
        linkify: true,         // 自动转换链接
        highlight: function (str, lang) {
            if (lang && hljs.getLanguage(lang)) {
                try {
                    return hljs.highlight(lang, str).value;
                } catch (err) {
                }
            }
            try {
                return hljs.highlightAuto(str).value;
            } catch (err) {
            }
            return ''; // use external default escaping
        }
    });
}
md.render(content);
// return html 

示例:

md.render('# Remarkable rulezz!')
// => <h1>Remarkable rulezz!</h1>

前台正常渲染代码高亮

后台我们已经能正常输出html代码了,但是这个时候,将html展示在前台我们还需要在前台引入highlight.js的相关css。

<link rel="stylesheet" href="//cdnjs.cloudflare.com/ajax/libs/highlight.js/9.1.0/styles/default.min.css">
<script src="//cdnjs.cloudflare.com/ajax/libs/highlight.js/9.1.0/highlight.min.js"></script>

关于Remarkable的更多内容,请参考remarkable
关于highlight.js的更多内容,请参考highlight.js

请关注专题:我的NodeJS学习之路(实践之路)

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

推荐阅读更多精彩内容

  • 请关注专题:我的NodeJS学习之路(实践之路) 小弟初涉node领域,不足之处,还请多多指教!欢迎Star、Fo...
    Devid阅读 2,945评论 1 4
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,127评论 25 707
  • ## 前端开发的工具 ### 编辑器: 1. 轻量级的,依靠插件:sublime;atom(github);vs ...
    浪流儿阅读 3,193评论 0 2
  • 世界上有两种东西你无法直视,一个是太阳,一个是人心。 —— 霍布斯 杭州保姆纵火事件新闻出来的时候,许多人不寒而栗...
    黑鸿升阅读 2,575评论 3 6
  • 早起,已经实行了三天,但是晚上有事睡得晚,第二天早起时头晕脑胀,但是我还是坚持下来,虽然没达到我心中的标准,但也比...
    萝莉心御姐范儿阅读 135评论 0 0