查看原文
其他

2.8 万 Star!生成虚假内容的神器:faker.js

南瓜 开源前哨 2021-02-01

【导语】:当你需要初始化数据库,或者要做压力测试的时候,如果手头没有足够多的真实数据,那你会很需要 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 defaker.locale = "de";

faker.js 还支持本地化部署增量导入,默认要求faker包含所有的本地数据。在生产环境中,你可能只想包含某个环境的数据,这种情况下,可以考虑使用这个方式。代码如下:

// loads only de localevar 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 - 


更多优秀开源项目(点击下方图片可跳转)




如果觉得本文介绍的开源项目不错,欢迎转发推荐给更多人。



分享、点赞和在看

支持我们分享更多优秀开源项目,谢谢!

    您可能也对以下帖子感兴趣

    文章有问题?点此查看未经处理的缓存