mirror of
https://github.com/nocobase/nocobase
synced 2024-11-15 15:16:31 +00:00
2.7 KiB
2.7 KiB
collections
提供 HTTP API 的方式管理数据表和字段
HTTP API
Collections
GET /api/collections
POST /api/collections
GET /api/collections/<collectionName>
PUT /api/collections/<collectionName>
DELETE /api/collections/<collectionName>
Fields
GET /api/collections/<collectionName>/fields
POST /api/collections/<collectionName>/fields
GET /api/collections/<collectionName>/fields/<fieldName>
PUT /api/collections/<collectionName>/fields/<fieldName>
DELETE /api/collections/<collectionName>/fields/<fieldName>
- 方便开发使用,API Route 上直接暴露的是 collectionName 和 fieldName,这样的可读性更好,但是如果修改了 collectionName 和 fieldName,可能会导致很多不可预知问题,所以要谨慎修改,或者不允许修改。
- fieldName 只在某 collectionName 下是唯一的。fields 表要为 collectionName 和 fieldName 建立唯一索引。
Repository API
CollectionRepository.load()
将符合条件的 collections 配置导入 db.collections
Definition
class CollectionRepository extends Repository {
async load(options?: LoadOptions): void;
}
Examples
const Collection = db.getCollection('collections');
await Collection.repository.load({
filter: {},
});
Model API
CollectionModel.migrate()
Definition
class CollectionModel extends Model {
migrate(options?: MigrateOptions): Promise<void>;
}
Examples
const collection = await Collection.repository.create({
name: 'tests',
});
await collection.migrate();
FieldModel.migrate()
Definition
class FieldModel extends Model {
migrate(options?: MigrateOptions): Promise<void>;
}
Examples
const Field = db.getCollection('fields');
const field = await Field.repository.create({
type: 'string',
name: 'title',
collectionName: 'tests',
});
await field.migrate();
plugin-collections 和 db.collection() 的区别
- plugin-collections 增加了绑定组件的相关参数:interface、uiSchema
- plugin-collections 的配置存储在数据表里,再同步给 db.collection()
- db.collection() 适用于配置较固定的系统表
- plugin-collections 适用于配置业务表
Examples
例子待补充简单的配置
Collection.repository.create({
name: 'tests',
fields: [
{ type: 'string', name: 'title' },
{ type: 'text', name: 'content' },
],
});
带 uiSchema 的配置
Collection.repository.create({
name: 'tests',
fields: [
{ type: 'string', name: 'title' },
{ type: 'text', name: 'content', uiSchema: {}, interface: 'markdown' },
],
});