2.8 万 Star!生成虚假内容的神器:faker.js
【导语】:当你需要初始化数据库,或者要做压力测试的时候,如果手头没有足够多的真实数据,那你会很需要 Faker 类工具。
和此前我们介绍的 PHP 版 Faker 一样,faker.js 是一个同类工具,它可以在浏览器和 Node.js 中生成大量假内容。
简介
faker.js 支持生成英文、中文等多语种信息。版本更新通常一个月一次, API 非常丰富,包括地址、商业、公司、数据库、日期、财务等等。
faker.js 很受欢迎,很多公司和个人在生产环境中实际使用。它在 Github 上快获得 2.8 万 Star,但并不是一个刚出来的新项目,最近再次登上 GitHub 日榜前三。
项目地址:
http://github.com/marak/faker.js/
下图为是 Demo 生成的例子,图片中人物是不存在的。
使用
在浏览器中使用:
<script src = "faker.js" type = "text/javascript"></script>
<script>
var randomName = faker.name.findName(); // Caitlyn Kerluke
var randomEmail = faker.internet.email(); // Rusty@arne.info
var randomCard = faker.helpers.createCard(); // random contact card containing many properties
</script>
在Node.js中使用:
var faker = require('faker');
var randomName = faker.name.findName(); // Rowan Nikolaus
var randomEmail = faker.internet.email(); // Kassandra.Haley@erich.biz
var randomCard = faker.helpers.createCard(); // random contact card containing many properties
如果想查询更加详细的使用内容,可以查询JSDoc API,地址如下:
http://marak.github.io/faker.js/
faker.js包含了一个超级有用的生成器方法:Faker.fake()。使用代码示例如下:
console.log(faker.fake("{{name.lastName}}, {{name.firstName}} {{name.suffix}}"));
// outputs: "Marks, Dean Sr."
其中name.lastName(), name.firstName(), and name.suffix()三个方法用来设置格式。
本地化部署
v2.0.0版本的faker.js支持多地部署,默认本地部署语言为英语。设置本地部署十分简单:
// sets locale to de
faker.locale = "de";
faker.js 还支持本地化部署增量导入,默认要求faker包含所有的本地数据。在生产环境中,你可能只想包含某个环境的数据,这种情况下,可以考虑使用这个方式。代码如下:
// loads only de locale
var faker = require('faker/locale/de');
设置随机种子
如果你想要连续的结果,可以通过设置自己的种子来实现:
faker.seed(123);
var firstRandom = faker.random.number();
// Setting the seed again resets the sequence.
faker.seed(123);
var secondRandom = faker.random.number();
console.log(firstRandom === secondRandom);
也可以先查看在线demo,来了解本项目的基本效果。demo地址如下:
https://rawgit.com/Marak/faker.js/master/examples/browser/index.html
- EOF -
更多优秀开源项目(点击下方图片可跳转)
如果觉得本文介绍的开源项目不错,欢迎转发推荐给更多人。
分享、点赞和在看
支持我们分享更多优秀开源项目,谢谢!