Strapi已经提供了默认的控制器来处理模型的 CRUD 操作,通常情况下我们应该尽可能地利用这些默认的控制器功能,而不是在自定义控制器中重新创建它们。以下是一个示例,在自定义控制器中使用默认控制器的 CRUD 功能:
'use strict';
module.exports = {
async find(ctx) {
const entities = await strapi.services.article.find(ctx.query);
return entities.map(entity => strapi.services.article.format(entity));
},
async findOne(ctx) {
const entity = await strapi.services.article.findOne(ctx.params);
return strapi.services.article.format(entity);
},
async create(ctx) {
const entity = await strapi.services.article.create(ctx.request.body);
return strapi.services.article.format(entity);
},
async update(ctx) {
const entity = await strapi.services.article.update(ctx.params, ctx.request.body);
return strapi.services.article.format(entity);
},
async delete(ctx) {
const entity = await strapi.services.article.delete(ctx.params);
return strapi.services.article.format(entity);
},
};
在上述代码中,我们在自定义控制器中使用默认的 article 服务来处理实际的 CRUD 操作(find,findOne,create,update和delete)。除此之外,我们还可以使用 service hook,使我们能够访问并重写这些默认服务方法的行为,而无需重新创建它们。