Skip to content
On this page

[DEPRECATED] uni-cloud-types

该依赖已废弃,请迁移到功能一致的 @uni-helper/uni-cloud-types

License

npm

uni-cloud 组件类型。uni-app-types 提供 uni-app 组件类型,uni-ui-types 提供 uni-ui 组件类型。

基于 这个 PRVolar 已经支持。

安装 Volar 之后,建议启用 Volar 的 Take Over Mode。如果不想启用 Take Over Mode,可以安装 TypeScript Vue Plugin (Volar)。启用或安装后需要重启 VSCode。

维护直到官方类型推出。

类型和文档的冲突之处,请以文档为准。

类型源代码在 ModyQyW/uni-helper。欢迎提交 ISSUE 和 PR 改进类型。

使用

  • 安装依赖
shell
npm i -D uni-cloud-types
1
  • 配置 tsconfig.json,确保 compilerOptions.types 中含有 @dcloudio/typesuni-cloud-typesinclude 包含了对应的 vue 文件
json
{
  "compilerOptions": {
    "types": ["@dcloudio/types", "uni-cloud-types"]
  },
  "vueCompilerOptions": {
    "experimentalRuntimeMode": "runtime-uni-app"
  },
  "include": ["src/**/*.vue"]
}
1
2
3
4
5
6
7
8
9
  • 重启编辑器 / IDE

类型

UnicloudDb (unicloud-db)

typescript
/**
 * @desc 服务空间信息
 */
export interface UnicloudDbSpaceInfo {
  /**
   * @desc 服务商
   * @desc aliyun 阿里云
   * @desc tencent 腾讯云
   */
  provider: 'aliyun' | 'tencent';
  /**
   * @desc 服务空间 ID
   */
  spaceId: string;
  /**
   * @desc 阿里云支持,在控制台服务空间列表中查看
   */
  clientSecret: string;
  /**
   * @desc 服务空间地址,阿里云支持
   */
  endpoint?: string;
}

/**
 * @desc 分页策略
 * @desc add 下一页的数据追加到之前的数据中,常用于滚动到底加载下一页
 * @desc replace 替换当前数据,常用于 PC 式交互,列表底部有页码分页按钮
 */
export type UnicloudDbPageData = 'add' | 'replace';

/**
 * @desc 加载数据时机
 * @desc auto 页面就绪后或属性变化后加载数据
 * @desc onready 页面就绪后不自动加载数据,属性变化后加载,适合在 onready 中接收上个页面的参数作为 where 条件时
 * @desc manual 手动模式,不自动加载数据,如果涉及到分页,需要先手动修改当前页再调用加载数据
 */
export type UnicloudDbLoadtime = 'auto' | 'onready' | 'manual';

export interface UnicloudDbProps {
  /**
   * @desc 服务空间信息
   */
  spaceInfo: UnicloudDbSpaceInfo;
  /**
   * @desc 表名
   */
  collection: string;
  /**
   * @desc 指定要查询的字段,多个字段用 , 分割
   */
  field: string;
  /**
   * @desc 查询条件,过滤记录 */
  where: string;
  /**
   * @desc 排序字段及正序倒序设置
   */
  orderby: string;
  /**
   * @desc 手动指定使用的关联关系
   */
  foreignKey: string;
  /**
   * @desc 分页策略
   * @desc add 下一页的数据追加到之前的数据中,常用于滚动到底加载下一页
   * @desc replace 替换当前数据,常用于 PC 式交互,列表底部有页码分页按钮
   * @desc 默认为 add
   */
  pageData: UnicloudDbPageData;
  /**
   * @desc 当前页
   */
  pageCurrent: number;
  /**
   * @desc 每页数据数量
   */
  pageSize: number;
  /**
   * @desc 是否查询总数据条数
   * @desc 默认 false
   */
  getcount: boolean;
  /**
   * @desc 指定查询结果是否仅返回数组第一条数据
   * @desc false:结果数据外会再用数组包裹一层,一般用于列表页
   * @desc true:直接返回结果数据,一般用于非列表页
   * @desc 默认 false
   */
  getone: boolean;
  /**
   * @desc 云端执行数据库查询的前或后,触发某个 action 函数操作,进行预处理或后处理
   * @desc 场景:前端无权操作的数据,比如阅读数 +1
   */
  action: string;
  /**
   * @desc 是否查询树状结构数据
   */
  gettree: boolean;
  /**
   * @desc gettree 的第一层级条件
   * @desc 此初始条件可以省略,不传 startWith 时默认从最顶级开始查询
   */
  startwith: string;
  /**
   * @desce gettree查询返回的树的最大层级,超过设定层级的节点不会返回
   * @desc 取值范围为 1 - 15
   * @dsec 默认为 10*/
  limitlevel: number;
  /**
   * @desc 对数据进行分组
   */
  groupby: string;
  /**
   * @desc 对数据进行分组统计
   */
  groupField: string;
  /**
   * @desc 是否对数据查询结果中重复的记录进行去重
   * @desc 默认为 false
   */
  distinct: boolean;
  /**
   * @desc 加载数据时机
   * @desc auto 页面就绪后或属性变化后加载数据
   * @desc onready 页面就绪后不自动加载数据,属性变化后加载,适合在 onready 中接收上个页面的参数作为 where 条件时
   * @desc manual 手动模式,不自动加载数据,如果涉及到分页,需要先手动修改当前页再调用加载数据
   * @desc 默认 auto
   */
  loadtime: UnicloudDbLoadtime;
  /**
   * @desc 发行 H5 ssr 时有效,用于保证服务器端渲染和前端加载的数据对应
   * @desc 页面同时出现 2 个及以上 unicloud-db 组件需要配置此属性,且要保证值整个应用唯一
   * @desc 默认根据页面路径 + unicloud-db 组件代码中的行号生成唯一值
   */
  ssrKey: string;
  /**
   * @desc 手动加载数据
   * @param param.clear 是否清空数据和分页信息,默认为 false
   * @param callback 回调函数,加载数据完或加载失败后触发
   */
  loadData: ({ clear }?: { clear: boolean }, callback?: () => any) => void;
  /**
   * @desc 加载更多数据,每加载成功一次,当前页 +1
   */
  loadMore: () => void;
  /**
   * @desc 清空已加载的数据,但不会重置当前分页信息
   */
  clear: () => void;
  /**
   * @desc 重置当前分页信息,但不会清空已加载的数据
   */
  reset: () => void;
  /**
   * @desc 清空并重新加载当前页面数据
   */
  refresh: () => void;
  /**
   * @desc 删除一个 item
   */
  remove: (
    id: string | string[],
    {
      action,
      confirmTitle,
      confirmContent,
      needConfirm,
      needLoading,
      loadingTitle,
      success,
      fail,
      complete,
    }?: {
      /**
       * @desc 云端执行数据库查询的前或后,触发某个 action 函数操作,进行预处理或后处理
       */
      action?: string;
      /**
       * @desc 删除确认框标题
       * @desc 默认为 提示
       */
      confirmTitle?: string;
      /**
       * @desc 删除确认框提示
       */
      confirmContent?: string;
      /**
       * @desc 控制是否有弹出框
       * @desc 默认为 true
       */
      needConfirm?: boolean;
      /**
       * @desc 是否显示 Loading
       * @desc 默认为 true
       */
      needLoading?: boolean;
      /**
       * @desc loading 的标题
       */
      loadingTitle?: string;
      /**
       * @desc 成功回调
       */
      success?: ({ code, message }: { code: string; message: string }) => void | Promise<void>;
      /**
       * @desc 失败回调
       */
      fail?: ({ message: string }) => void | Promise<void>;
      /**
       * @desc 完成回调
       */
      complete?: () => void | Promise<void>;
    },
  ) => void;
  /**
   * @desc 新增一个 item
   */
  add: (
    value: Record<string, any>,
    {
      action,
      showToast,
      toastTitle,
      needLoading,
      loadingTitle,
      success,
      fail,
      complete,
    }?: {
      /**
       * @desc 云端执行数据库查询的前或后,触发某个 action 函数操作,进行预处理或后处理
       */
      action?: string;
      /**
       * @desc 是否显示更新成功后的提示框
       * @desc 默认为 true
       */
      showToast?: boolean;
      /**
       * @desc 新增成功后的 toast 提示
       * @desc 默认为 新增成功
       */
      toastTitle?: string;
      /**
       * @desc 是否显示 Loading
       * @desc 默认为 true
       */
      needLoading?: boolean;
      /**
       * @desc loading 的标题
       */
      loadingTitle?: string;
      /**
       * @desc 成功回调
       */
      success?: ({ code, message }: { code: string; message: string }) => void | Promise<void>;
      /**
       * @desc 失败回调
       */
      fail?: ({ message: string }) => void | Promise<void>;
      /**
       * @desc 完成回调
       */
      complete?: () => void | Promise<void>;
    },
  ) => void;
  /**
   * @desc 更新一个 item
   */
  update: (
    id: string,
    value: Record<string, any>,
    {
      action,
      showToast,
      toastTitle,
      needLoading,
      loadingTitle,
      success,
      fail,
      complete,
    }?: {
      /**
       * @desc 云端执行数据库查询的前或后,触发某个 action 函数操作,进行预处理或后处理
       */
      action?: string;
      /**
       * @desc 是否显示更新成功后的提示框
       * @desc 默认为 true
       */
      showToast?: boolean;
      /**
       * @desc 新增成功后的 toast 提示
       * @desc 默认为 修改成功
       */
      toastTitle?: string;
      /**
       * @desc 控制是否有弹出框
       * @desc 默认为 true
       */
      needConfirm?: boolean;
      /**
       * @desc 是否显示 Loading
       * @desc 默认为 true
       */
      needLoading?: boolean;
      /**
       * @desc loading 的标题
       */
      loadingTitle?: string;
      /**
       * @desc 成功回调
       */
      success?: ({ code, message }: { code: string; message: string }) => void | Promise<void>;
      /**
       * @desc 失败回调
       */
      fail?: ({ message: string }) => void | Promise<void>;
      /**
       * @desc 完成回调
       */
      complete?: () => void | Promise<void>;
    },
  ) => void;
  /**
   * @desc 获取 data
   */
  dataList: any;
  /**
   * @desc 成功回调
   * @desc 联网返回结果后,若希望先修改下数据再渲染界面,则在本方法里对 data 进行修改
   * @param data 当前查询结果
   * @param ended 是否有更多数据
   * @param pagination 分页信息
   * @param pagination.size 每页数据量
   * @param pagination.count 数据总量
   */
  onLoad: (data: any, ended: boolean, pagination: { size: number; count: number }) => void;
  /**
   * @desc 失败回调
   */
  onError: (event: { message: string }) => void;
}

/**
 * @desc 数据库查询组件,对 uni-clientdb 的 js 库的再封装
 */
export type UnicloudDb = Component<Partial<UnicloudDbProps>>;
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349

致谢

最初在 uni-base-components-types 得到了灵感。

基于 这个 PR 完成。

Released under the MIT License.