[云开发1]-快速开发一个问卷调查云应用(后端)

2024-02-01 22:48

本文主要是介绍[云开发1]-快速开发一个问卷调查云应用(后端),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

通过Sails.js开发RESTful API

阅读这篇blog大约需要5分钟

通过一个小例子MVP来学习一下Sails.js这个框架。模拟的场景需求是设计一个问卷调查。

在这里插入图片描述

后端使用Sails.js,前端通过OpenUI5来实现。

The first 90% of the code accounts for the first 90% of the development time. The remaining 10% of the code accounts for the other 90% of the development time. --Tom Cargill

创建模型

简单设计了一下,一个问卷会包含多个问题,每个用户填完后就是一个反馈。每个反馈里包含了全部的问题回答。主要包括这些数据:

  • Questionaires 问卷
  • Questions 问题
  • Feedbacks 反馈
  • Answers 每个问题的回答

依次通过sails的命令来创建api:

sails generate api Questionairessails generate api Questionssails genreate api Feedbackssails genrate api Answers

Sails.js会通过Waterline的ORM来自动根据模型定义来自动生成表和关系。而且Sails.js默认自带了一个简单的数据库实现,它是通过JSON文件保存的。

自定义API

开发一个自定义的api,可以通过action来完成。

sails generate action /feedback/create

它会自动生成文件controller/feedback/create.js,定制代码写在create.js中。这里是接口函数代码:

fn: async function (inputs) {Questionnaires.create(q);const feedback = {"fb_owner": inputs.id};const createdFeedback = await Feedbacks.create(feedback).fetch();let answers = inputs.answers.map((input) => {input.feedback = createdFeedback.id;return input;});const createdAnswers = await Answers.createEach(answers).fetch();return createdFeedback;}

自定义路由

修改config/routes.js文件,增加一行配置:

  'POST /api/v1/feedback/create' : {action: 'feedback/create'},

API测试

http://localhost:1337/api/v1/feedback/create

POST数据创建一个问卷反馈:

{
"id": 11,
"answers": [
{"question": 21,"answer": 0
}, 
{"question": 22,"answer": 1
}, 
{"question": 23,"answer": 2
}
]
}

返回数据:
states 201 ok.

后台数据创建成功。

{"createdAt": 1581583005224,"updatedAt": 1581583005224,"id": 9,"fb_owner": 11
}

小结

在这个例子中只是用到了Sails.js里API的一小部分功能,它是一个类似Ruby on rails的JS框架,个人感觉还是很方便的,对于原型demo开发,能够节约不少的时间。

项目代码

  • https://github.com/rangwei/cloud-blogs/tree/master/b08/arctic-db

参考阅读

  • https://sailsjs.com/documentation/concepts

这篇关于[云开发1]-快速开发一个问卷调查云应用(后端)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/668720

相关文章

CSS中的Static、Relative、Absolute、Fixed、Sticky的应用与详细对比

《CSS中的Static、Relative、Absolute、Fixed、Sticky的应用与详细对比》CSS中的position属性用于控制元素的定位方式,不同的定位方式会影响元素在页面中的布... css 中的 position 属性用于控制元素的定位方式,不同的定位方式会影响元素在页面中的布局和层叠关

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

使用Python开发一个现代化屏幕取色器

《使用Python开发一个现代化屏幕取色器》在UI设计、网页开发等场景中,颜色拾取是高频需求,:本文主要介绍如何使用Python开发一个现代化屏幕取色器,有需要的小伙伴可以参考一下... 目录一、项目概述二、核心功能解析2.1 实时颜色追踪2.2 智能颜色显示三、效果展示四、实现步骤详解4.1 环境配置4.

Python使用smtplib库开发一个邮件自动发送工具

《Python使用smtplib库开发一个邮件自动发送工具》在现代软件开发中,自动化邮件发送是一个非常实用的功能,无论是系统通知、营销邮件、还是日常工作报告,Python的smtplib库都能帮助我们... 目录代码实现与知识点解析1. 导入必要的库2. 配置邮件服务器参数3. 创建邮件发送类4. 实现邮件

Python使用Tkinter打造一个完整的桌面应用

《Python使用Tkinter打造一个完整的桌面应用》在Python生态中,Tkinter就像一把瑞士军刀,它没有花哨的特效,却能快速搭建出实用的图形界面,作为Python自带的标准库,无需安装即可... 目录一、界面搭建:像搭积木一样组合控件二、菜单系统:给应用装上“控制中枢”三、事件驱动:让界面“活”

基于Python开发一个有趣的工作时长计算器

《基于Python开发一个有趣的工作时长计算器》随着远程办公和弹性工作制的兴起,个人及团队对于工作时长的准确统计需求日益增长,本文将使用Python和PyQt5打造一个工作时长计算器,感兴趣的小伙伴可... 目录概述功能介绍界面展示php软件使用步骤说明代码详解1.窗口初始化与布局2.工作时长计算核心逻辑3

如何确定哪些软件是Mac系统自带的? Mac系统内置应用查看技巧

《如何确定哪些软件是Mac系统自带的?Mac系统内置应用查看技巧》如何确定哪些软件是Mac系统自带的?mac系统中有很多自带的应用,想要看看哪些是系统自带,该怎么查看呢?下面我们就来看看Mac系统内... 在MAC电脑上,可以使用以下方法来确定哪些软件是系统自带的:1.应用程序文件夹打开应用程序文件夹

python web 开发之Flask中间件与请求处理钩子的最佳实践

《pythonweb开发之Flask中间件与请求处理钩子的最佳实践》Flask作为轻量级Web框架,提供了灵活的请求处理机制,中间件和请求钩子允许开发者在请求处理的不同阶段插入自定义逻辑,实现诸如... 目录Flask中间件与请求处理钩子完全指南1. 引言2. 请求处理生命周期概述3. 请求钩子详解3.1