利用 Sinon 测试 AJAX 请求

AJAX BDD DOM HTTP Mocha Mock Promise XHR jQuery 异步 测试

在Web前端测试中,常常会需要测试AJAX行为。 为了简化测试的环境要求需要提供虚拟的测试环境。 Sinonjs在这方面提供了两类API:

  • Fake XMLHttpRequest:覆盖DOM API中的XHR。使得我们可以捕获所有用户构建的XHR对象,包括直接构造的XMLHttpRequest,也包括通过jQuery等工具构造的。因此可以测试XHR构造是否正确。
  • Fake Server:Mock服务器行为。如果我们只希望Mock服务器的Response,可以使用Fake Server。

Promise异步编程范式

mongoose JavaScript MongoDB Node.js Promise 回调函数

Promise是JavaScript中的一种异步编程范式, 一个Promise对象表示一个即将完成但还未完成的操作。 鉴于JavaScript中异步和回调的编程风格, Promise模式可以有效地避免『Callback Hell』。

Promise 最初由 Q, jQuery 1.5, RSVP.js, bluebird 等实现, 现有 Promises/A+ 社区标准可以参考:https://promisesaplus.com/,在 纳入 ES6 后浏览器和 Node.js 都相继给出了实现。

初始化

传入一个回调函数即可初始化一个Promise对象padmin

var padmin = new Promise(function(resolve, reject){
    user.find({role: 'admin'}, function(err, admins){
        if(err) reject(err);
        else resolve(admins);
    });
});

Vim 中为 Markdown 配置回车展开

Vim-Practice Markdown Vim Jekyll

靠Vim写Jekyll博客已经很久了,编写代码块(Code Fence)时键入前后的```, 以及手动编写文章头信息(Front Matter)一直是个麻烦的事情。 Harttle今天就通过Vim键盘映射来对这两种语法提供回车展开支持。最终效果如下:

使用systemd管理Node.js应用

Linux MongoDB Node.js Redis systemd

systemd 是 Linux 下的一款系统和服务管理器, 该软件的初衷是提供精确的服务间依赖,以此支持并行启动来提高性能。 越来越多的Linux发行版都由sysvinit迁移到了systemd(包括Debian!)。 在这些Linux系统中,用原生的systemd来托管Node.js进程足够满足一般开发者的要求。 借由systemd可以很方便地处理依赖关系和监测日志。

systemctl

systemctl是查询和控制systemd的主要命令,下面以mongod为例介绍常用参数:

MongoDBNode.js下非常常见的NoSQL数据库,在ArchLinux下通过pacman安装:pacman install mongodb,安装成功后mongod即为可用的systemd服务。

# 查看服务状态
systemctl status mongod
# 启动服务
systemctl start mongod
# 停止服务
systemctl stop mongod
# 重启服务
systemctl restart mongod
# 设为自启动
systemctl enable mongod
# 取消自启动
systemctl disable mongod

404 错误处理:重定向还是接 404?

AJAX HTML HTTP JavaScript 搜索引擎

常见的 HTTP 服务器(比如 Spring、Express、Django,甚至 nginx) 一般都会提供自定义错误页面的方式。 也就是说当 4xx、5xx 错误发生时,服务器直接返回配置好的错误页面,隐藏原始的错误信息。 不恰当地配置这些页面有时会产生非常坏的影响,本文以 404 为例对比不同的处理方式:

  • 返回包含 404 内容的页面,同时给出 404 状态码。比如 Google、Github、Facebook、Amazon、Linkedin。
  • 重定向(302/303)至统一的 URL,该 URL 给出具有 404 信息的页面。比如百度、淘宝、腾讯。

ES6生成器:可迭代协议与迭代器协议

JavaScript 迭代器 生成器 ES6

ES6(ECMAScript 2015)中提出了生成器的概念,进一步完整了JavaScript语言。 本文介绍了可迭代协议与迭代器协议的概念区别,以及生成器的声明与使用方法。

生成器函数

生成器函数是用来返回生成器的函数,生成器是一种有状态的迭代器, 可实现较复杂的迭代行为,比如生成ID。 生成器函数使用function*语法来定义:

function* idMaker(){
    var index = 0;
    while(index<3){
        yield index++;
    }
}

生成器函数也可以通过GeneratorFunction(类似Function)、function* expression来定义(可以使用匿名函数)。

导航: 上一页 下一页

加载中...

🔝