介绍
feathers是一个轻量级的Web框架,在Github上相当受欢迎,stars数高达12.6k+,开源遵循MIT License,feathers使用JavaScript或TypeScript创建实时应用程序和REST api。Feathers可以与任何后端技术交互,支持超过12个数据库,与任何前端技术如React、VueJS、Angular、React Native、Android或iOS一起进行开发。
Github
https://github.com/feathersjs/feathers
feathers有何与众不同?
- JavaScript和TypeScript构建
使用最新的语言特性,Feathers是一个小的库,它提供了创建复杂应用程序的结构,但又足够灵活,不会妨碍开发。
- 灵活的插件
拥有大量插件生态系统
- 多数据库支持
Feathers为12个以上的数据库提供了现成的适配器。可以在一个应用程序中拥有多个数据库,并且由于一致的查询接口,可以毫不费力地将它们协同起来。
- 兼容性好
Feathers可以用同样的方式在服务器上使用Node.js,在浏览器框架中使用React、Angular、VueJS,或者在移动设备上使用React Native。
- 面向服务的模式
Feathers从一开始就提供了构建面向服务的应用程序的结构。当你最终需要将你的应用分解成微服务时,很容易过渡。
- 即时实时REST api
Feathers通过服务提供即时CRUD功能,通过websockets自动公开RESTful API和实时后端
创建第一个应用
$ npm install -g @feathersjs/cli# yarn global add @feathersjs/cli$ mkdir my-app$ cd my-app$ feathers generate app$ npm start# yarn start
下面创建一个带有简单消息服务的Feathers应用程序,该服务允许创建新消息并查找所有现有消息
const feathers = require('@feathersjs/feathers');const app = feathers();// 允许创建新消息的消息服务// 并返回所有现有的消息class MessageService { constructor() { this.messages = []; } async find () { // 只要返回我们所有的信息 return this.messages; } async create (data) { // 新消息是带有唯一标识符的合并数据 // 使用消息长度,因为只要我们添加一个消息,它就会改变 const message = { id: this.messages.length, text: data.text } // 向列表中添加新消息 this.messages.push(message); return message; }}// 在Feathers应用程序上注册消息服务app.use('messages', new MessageService());// 每次创建新消息时记录日志app.service('messages').on('created', message => { console.log('A new message has been created', message);});// 创建新消息并记录日志的函数// 所有现有的消息const main = async () => { // 在消息服务上创建一个新消息 await app.service('messages').create({ text: 'Hello Feathers' }); await app.service('messages').create({ text: 'Hello again' }); // 查找所有现有消息 const messages = await app.service('messages').find(); console.log('All messages', messages);};main();
总结
详细的使用以及开发流程可以参考详细的官方文档,包括授权、安全性、单元测试、服务等等,对JavaScript和Typescript以及Web开发感兴趣的小伙伴们不要错过啦!