开源实时应用程序和REST api Web开发框架(js&ts)——feathers

介绍

feathers是一个轻量级的Web框架,在Github上相当受欢迎,stars数高达12.6k+,开源遵循MIT License,feathers使用JavaScript或TypeScript创建实时应用程序和REST api。Feathers可以与任何后端技术交互,支持超过12个数据库,与任何前端技术如React、VueJS、Angular、React Native、Android或iOS一起进行开发。




开源实时应用程序和REST api Web开发框架(js&ts)——feathers



Github

https://github.com/feathersjs/feathers

feathers有何与众不同?

使用最新的语言特性,Feathers是一个小的库,它提供了创建复杂应用程序的结构,但又足够灵活,不会妨碍开发。

拥有大量插件生态系统

Feathers为12个以上的数据库提供了现成的适配器。可以在一个应用程序中拥有多个数据库,并且由于一致的查询接口,可以毫不费力地将它们协同起来。

Feathers可以用同样的方式在服务器上使用Node.js,在浏览器框架中使用React、Angular、VueJS,或者在移动设备上使用React Native。

Feathers从一开始就提供了构建面向服务的应用程序的结构。当你最终需要将你的应用分解成微服务时,很容易过渡。

Feathers通过服务提供即时CRUD功能,通过websockets自动公开RESTful API和实时后端




开源实时应用程序和REST api Web开发框架(js&ts)——feathers




创建第一个应用

nbsp;npm install -g @feathersjs/cli
# yarn global add @feathersjs/cli
nbsp;mkdir my-app
nbsp;cd my-app
nbsp;feathers generate app
nbsp;npm start
# yarn start


开源实时应用程序和REST api Web开发框架(js&ts)——feathers


开源实时应用程序和REST api Web开发框架(js&ts)——feathers


开源实时应用程序和REST api Web开发框架(js&ts)——feathers


开源实时应用程序和REST api Web开发框架(js&ts)——feathers


开源实时应用程序和REST api Web开发框架(js&ts)——feathers

下面创建一个带有简单消息服务的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开发感兴趣的小伙伴们不要错过啦!


JavaScript权威指南 ¥111.2 购买
展开阅读全文

页面更新:2024-03-19

标签:应用程序   实时   框架   标识符   毫不费力   适配器   分解   插件   灵活   消息   结构   数据库   详细   技术   科技   日志

1 2 3 4 5

上滑加载更多 ↓
推荐阅读:
友情链接:
更多:

本站资料均由网友自行发布提供,仅用于学习交流。如有版权问题,请与我联系,QQ:4156828  

© CopyRight 2020-2024 All Rights Reserved. Powered By 71396.com 闽ICP备11008920号-4
闽公网安备35020302034903号

Top