一、service官方解释
简单来说,Service就是在复杂业务场景下用于做业务逻辑封装的一个抽象蹭,提供这个抽象有以下几个好处:
1、保持Controller中的逻辑更加简洁
2、保持业务逻辑的独立性,抽象出来的Service可以被多个Controller重复调用。
二、使用方法
- 首先在app文件夹下创建service文件夹
- 然后在service文件夹创建xxx.js
拿我们上一章的代码举个例子:
const Service = require("egg").Service;
class StudentService extends Service {
async getStudentList() {
try {
let studentList = await this.app.model.Student.findAll()
return studentList
} catch (e) {
return null
}
}
}
module.exports = StudentService
- 接下来就是如何使用它
//学生列表
async index() {
let list = await this.ctx.service.student.getStudentList()
if (list) {
this.ctx.body = {
code: 200,
data: list
}
} else {
this.ctx.body = {
code: 400,
msg: '服务器异常,请与管理员联系'
}
}
}
- 再举个例子,比如说写个创建学生的方法
//创建学生
async createStudent(name, achievement, clazz_id) {
try {
await this.app.model.Student.create({
name,
achievement,
clazz_id
})
} catch (e) {
return false
}
}
- 接下来就是如何使用
//新增学生
async create() {
let name = this.ctx.request.body.data.name
let achievement = this.ctx.request.body.data.achievement
let clazz_id = this.ctx.request.body.data.clazz_id
let result = await this.ctx.service.student.createStudent(name, achievement, clazz_id)
if (result) {
this.ctx.body = {
code: 200,
msg: '添加成功'
}
} else {
this.ctx.body = {
code: 400,
msg: '数据添加异常,请与管理员联系'
}
}
}
文章的末尾,希望大家都尝试着把上一章节的代码进行整改,优化一下代码规范,老样子,最后一章节,我会放上git的地址,仅供参考。今天给大家带来一首《粉雾海》
传送门:
1、第一章 Egg框架概述:https://www.jianshu.com/p/bfdaecb5a18c
2、第二章 路由与控制器:https://www.jianshu.com/p/62edeb088d76
3、第三章 插件:https://www.jianshu.com/p/e8d39f446f46
4、第四章 用户登录状态(上) :https://www.jianshu.com/p/a43759eab484
5、第五章 用户登录状态(下) :https://www.jianshu.com/p/06937d8d1241
6、第六章 中间件:https://www.jianshu.com/p/e369798c0e42
7、第七章 数据持久化 :https://www.jianshu.com/p/8da2af92526c