amis-formula 3.1.0 → 3.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/esm/evalutor.d.ts CHANGED
@@ -181,14 +181,12 @@ export declare class Evaluator {
181
181
  return: any;
182
182
  }, args: Array<any>): any;
183
183
  /**
184
- * 示例:IF(A, B, C)
184
+ * 如果满足条件condition,则返回consequent,否则返回alternate,支持多层嵌套IF函数。
185
185
  *
186
- * 如果满足条件A,则返回B,否则返回C,支持多层嵌套IF函数。
187
- *
188
- * 也可以用表达式如:A ? B : C
186
+ * 等价于直接用JS表达式如:condition ? consequent : alternate。
189
187
  *
190
188
  * @example IF(condition, consequent, alternate)
191
- * @param {expression} condition - 条件表达式.
189
+ * @param {expression} condition 条件表达式。例如:语文成绩>80
192
190
  * @param {any} consequent 条件判断通过的返回结果
193
191
  * @param {any} alternate 条件判断不通过的返回结果
194
192
  * @namespace 逻辑函数
@@ -197,32 +195,32 @@ export declare class Evaluator {
197
195
  */
198
196
  fnIF(condition: () => any, trueValue: () => any, falseValue: () => any): any;
199
197
  /**
200
- * 条件全部符合,返回 true,否则返回 false
198
+ * 条件全部符合,返回 true,否则返回 false
201
199
  *
202
- * 示例:AND(语文成绩>80, 数学成绩>80)
200
+ * 示例:AND(语文成绩>80, 数学成绩>80)
203
201
  *
204
- * 语文成绩和数学成绩都大于 80,则返回 true,否则返回 false
202
+ * 语文成绩和数学成绩都大于 80,则返回 true,否则返回 false
205
203
  *
206
- * 也可以直接用表达式如:语文成绩>80 && 数学成绩>80
204
+ * 等价于直接用JS表达式如:语文成绩>80 && 数学成绩>80
207
205
  *
208
206
  * @example AND(expression1, expression2, ...expressionN)
209
- * @param {...expression} conditions - 条件表达式.
207
+ * @param {...expression} conditions 条件表达式,多个用逗号隔开。例如:语文成绩>80, 数学成绩>80
210
208
  * @namespace 逻辑函数
211
209
  *
212
210
  * @returns {boolean}
213
211
  */
214
212
  fnAND(...condtions: Array<() => any>): boolean;
215
213
  /**
216
- * 条件任意一个满足条件,返回 true,否则返回 false
214
+ * 条件任意一个满足条件,返回 true,否则返回 false
217
215
  *
218
- * 示例:OR(语文成绩>80, 数学成绩>80)
216
+ * 示例:OR(语文成绩>80, 数学成绩>80)
219
217
  *
220
- * 语文成绩和数学成绩任意一个大于 80,则返回 true,否则返回 false
218
+ * 语文成绩和数学成绩任意一个大于 80,则返回 true,否则返回 false
221
219
  *
222
- * 也可以直接用表达式如:语文成绩>80 || 数学成绩>80
220
+ * 等价于直接用JS表达式如:语文成绩>80 || 数学成绩>80
223
221
  *
224
222
  * @example OR(expression1, expression2, ...expressionN)
225
- * @param {...expression} conditions - 条件表达式.
223
+ * @param {...expression} conditions 条件表达式,多个用逗号隔开。例如:语文成绩>80, 数学成绩>80
226
224
  * @namespace 逻辑函数
227
225
  *
228
226
  * @returns {boolean}
@@ -231,9 +229,12 @@ export declare class Evaluator {
231
229
  /**
232
230
  * 异或处理,多个表达式组中存在奇数个真时认为真。
233
231
  *
234
- * @example XOR(condition1, condition2)
235
- * @param {expression} condition1 - 条件表达式1
236
- * @param {expression} condition2 - 条件表达式2
232
+ * 示例:XOR(语文成绩 > 80, 数学成绩 > 80, 英语成绩 > 80)
233
+ *
234
+ * 三门成绩中有一门或者三门大于 80,则返回 true,否则返回 false。
235
+ *
236
+ * @example XOR(condition1, condition2, ...expressionN)
237
+ * @param {...expression} condition 条件表达式,多个用逗号隔开。例如:语文成绩>80, 数学成绩>80
237
238
  * @namespace 逻辑函数
238
239
  *
239
240
  * @returns {boolean}
@@ -242,18 +243,19 @@ export declare class Evaluator {
242
243
  /**
243
244
  * 判断函数集合,相当于多个 else if 合并成一个。
244
245
  *
245
- * 示例:IFS(语文成绩 > 80, "优秀", 语文成绩 > 60, "良", "继续努力")
246
+ * 示例:IFS(语文成绩 > 80, "优秀", 语文成绩 > 60, "良", "继续努力")
246
247
  *
247
248
  * 如果语文成绩大于 80,则返回优秀,否则判断大于 60 分,则返回良,否则返回继续努力。
248
249
  *
249
250
  * @example IFS(condition1, result1, condition2, result2,...conditionN, resultN)
250
- * @param {...any} args - 条件,返回值集合
251
+ * @param {...expression} condition 条件表达式
252
+ * @param {...any} result 返回值
251
253
  * @namespace 逻辑函数
252
254
  * @returns {any} 第一个满足条件的结果,没有命中的返回 false。
253
255
  */
254
256
  fnIFS(...args: Array<() => any>): any;
255
257
  /**
256
- * 返回传入数字的绝对值
258
+ * 返回传入数字的绝对值。
257
259
  *
258
260
  * @example ABS(num)
259
261
  * @param {number} num - 数值
@@ -263,7 +265,7 @@ export declare class Evaluator {
263
265
  */
264
266
  fnABS(a: number): number;
265
267
  /**
266
- * 获取最大值,如果只有一个参数且是数组,则计算这个数组内的值
268
+ * 获取最大值,如果只有一个参数且是数组,则计算这个数组内的值。
267
269
  *
268
270
  * @example MAX(num1, num2, ...numN)
269
271
  * @param {...number} num - 数值
@@ -273,7 +275,7 @@ export declare class Evaluator {
273
275
  */
274
276
  fnMAX(...args: Array<any>): any;
275
277
  /**
276
- * 获取最小值,如果只有一个参数且是数组,则计算这个数组内的值
278
+ * 获取最小值,如果只有一个参数且是数组,则计算这个数组内的值。
277
279
  *
278
280
  * @example MIN(num1, num2, ...numN)
279
281
  * @param {...number} num - 数值
@@ -283,7 +285,7 @@ export declare class Evaluator {
283
285
  */
284
286
  fnMIN(...args: Array<number>): any;
285
287
  /**
286
- * 求和,如果只有一个参数且是数组,则计算这个数组内的值
288
+ * 求和,如果只有一个参数且是数组,则计算这个数组内的值。
287
289
  *
288
290
  * @example SUM(num1, num2, ...numN)
289
291
  * @param {...number} num - 数值
@@ -293,7 +295,7 @@ export declare class Evaluator {
293
295
  */
294
296
  fnSUM(...args: Array<number>): any;
295
297
  /**
296
- * 将数值向下取整为最接近的整数
298
+ * 将数值向下取整为最接近的整数。
297
299
  *
298
300
  * @example INT(num)
299
301
  * @param {number} num - 数值
@@ -303,7 +305,7 @@ export declare class Evaluator {
303
305
  */
304
306
  fnINT(n: number): number;
305
307
  /**
306
- * 返回两数相除的余数,参数 number 是被除数,divisor 是除数
308
+ * 返回两数相除的余数,参数 number 是被除数,divisor 是除数。
307
309
  *
308
310
  * @example MOD(num, divisor)
309
311
  * @param {number} num - 被除数
@@ -314,7 +316,7 @@ export declare class Evaluator {
314
316
  */
315
317
  fnMOD(a: number, b: number): number;
316
318
  /**
317
- * 圆周率 3.1415...
319
+ * 圆周率 3.1415...。
318
320
  *
319
321
  * @example PI()
320
322
  * @namespace 数学函数
@@ -327,7 +329,7 @@ export declare class Evaluator {
327
329
  *
328
330
  * @example ROUND(num[, numDigits = 2])
329
331
  * @param {number} num - 要处理的数字
330
- * @param {number} numDigits - 小数位数
332
+ * @param {number} numDigits - 小数位数,默认为2
331
333
  * @namespace 数学函数
332
334
  *
333
335
  * @returns {number} 传入数值四舍五入后的结果
@@ -338,7 +340,7 @@ export declare class Evaluator {
338
340
  *
339
341
  * @example FLOOR(num[, numDigits=2])
340
342
  * @param {number} num - 要处理的数字
341
- * @param {number} numDigits - 小数位数
343
+ * @param {number} numDigits - 小数位数,默认为2
342
344
  * @namespace 数学函数
343
345
  *
344
346
  * @returns {number} 传入数值向下取整后的结果
@@ -349,7 +351,7 @@ export declare class Evaluator {
349
351
  *
350
352
  * @example CEIL(num[, numDigits=2])
351
353
  * @param {number} num - 要处理的数字
352
- * @param {number} numDigits - 小数位数
354
+ * @param {number} numDigits - 小数位数,默认为2
353
355
  * @namespace 数学函数
354
356
  *
355
357
  * @returns {number} 传入数值向上取整后的结果
@@ -366,7 +368,7 @@ export declare class Evaluator {
366
368
  */
367
369
  fnSQRT(n: number): number;
368
370
  /**
369
- * 返回所有参数的平均值,如果只有一个参数且是数组,则计算这个数组内的值
371
+ * 返回所有参数的平均值,如果只有一个参数且是数组,则计算这个数组内的值。
370
372
  *
371
373
  * @example AVG(num1, num2, ...numN)
372
374
  * @param {...number} num - 要处理的数字
@@ -376,7 +378,7 @@ export declare class Evaluator {
376
378
  */
377
379
  fnAVG(...args: Array<any>): number;
378
380
  /**
379
- * 返回数据点与数据均值点之差(数据偏差)的平方和,如果只有一个参数且是数组,则计算这个数组内的值
381
+ * 返回数据点与数据均值点之差(数据偏差)的平方和,如果只有一个参数且是数组,则计算这个数组内的值。
380
382
  *
381
383
  * @example DEVSQ(num1, num2, ...numN)
382
384
  * @param {...number} num - 要处理的数字
@@ -386,7 +388,7 @@ export declare class Evaluator {
386
388
  */
387
389
  fnDEVSQ(...args: Array<any>): number | null;
388
390
  /**
389
- * 数据点到其算术平均值的绝对偏差的平均值
391
+ * 数据点到其算术平均值的绝对偏差的平均值。
390
392
  *
391
393
  * @example AVEDEV(num1, num2, ...numN)
392
394
  * @param {...number} num - 要处理的数字
@@ -396,7 +398,7 @@ export declare class Evaluator {
396
398
  */
397
399
  fnAVEDEV(...args: Array<any>): number | null;
398
400
  /**
399
- * 数据点的调和平均值,如果只有一个参数且是数组,则计算这个数组内的值
401
+ * 数据点的调和平均值,如果只有一个参数且是数组,则计算这个数组内的值。
400
402
  *
401
403
  * @example HARMEAN(num1, num2, ...numN)
402
404
  * @param {...number} num - 要处理的数字
@@ -406,7 +408,7 @@ export declare class Evaluator {
406
408
  */
407
409
  fnHARMEAN(...args: Array<any>): number | null;
408
410
  /**
409
- * 数据集中第 k 个最大值
411
+ * 数据集中第 k 个最大值。
410
412
  *
411
413
  * @example LARGE(array, k)
412
414
  * @param {array} nums - 要处理的数字
@@ -417,7 +419,7 @@ export declare class Evaluator {
417
419
  */
418
420
  fnLARGE(nums: Array<any>, k: number): any;
419
421
  /**
420
- * 将数值转为中文大写金额
422
+ * 将数值转为中文大写金额。
421
423
  *
422
424
  * @example UPPERMONEY(num)
423
425
  * @param {number} num - 要处理的数字
@@ -429,9 +431,9 @@ export declare class Evaluator {
429
431
  /**
430
432
  * 返回大于等于 0 且小于 1 的均匀分布随机实数。每一次触发计算都会变化。
431
433
  *
432
- * 示例:`RAND()*100`
434
+ * 示例:`RAND()*100`,
433
435
  *
434
- * 返回 0-100 之间的随机数
436
+ * 返回 0-100 之间的随机数。
435
437
  *
436
438
  * @example RAND()
437
439
  * @namespace 数学函数
@@ -440,7 +442,7 @@ export declare class Evaluator {
440
442
  */
441
443
  fnRAND(): number;
442
444
  /**
443
- * 取数据最后一个
445
+ * 取数据最后一个。
444
446
  *
445
447
  * @example LAST(array)
446
448
  * @param {...number} arr - 要处理的数组
@@ -473,7 +475,7 @@ export declare class Evaluator {
473
475
  */
474
476
  fnRIGHT(text: string, len: number): string;
475
477
  /**
476
- * 计算文本的长度
478
+ * 计算文本的长度。
477
479
  *
478
480
  * @example LEN(text)
479
481
  * @param {string} text - 要处理的文本
@@ -483,7 +485,7 @@ export declare class Evaluator {
483
485
  */
484
486
  fnLEN(text: string): number;
485
487
  /**
486
- * 计算文本集合中所有文本的长度
488
+ * 计算文本集合中所有文本的长度。
487
489
  *
488
490
  * @example LENGTH(textArr)
489
491
  * @param {string[]} textArr - 要处理的文本集合
@@ -493,7 +495,7 @@ export declare class Evaluator {
493
495
  */
494
496
  fnLENGTH(...args: any[]): any;
495
497
  /**
496
- * 判断文本是否为空
498
+ * 判断文本是否为空。
497
499
  *
498
500
  * @example ISEMPTY(text)
499
501
  * @param {string} text - 要处理的文本
@@ -503,7 +505,7 @@ export declare class Evaluator {
503
505
  */
504
506
  fnISEMPTY(text: string): boolean;
505
507
  /**
506
- * 将多个传入值连接成文本
508
+ * 将多个传入值连接成文本。
507
509
  *
508
510
  * @example CONCATENATE(text1, text2, ...textN)
509
511
  * @param {...string} text - 文本集合
@@ -515,7 +517,7 @@ export declare class Evaluator {
515
517
  /**
516
518
  * 返回计算机字符集的数字代码所对应的字符。
517
519
  *
518
- * `CHAR(97)` 等价于 "a"
520
+ * 示例:`CHAR(97)` 等价于 "a"
519
521
  *
520
522
  * @example CHAR(code)
521
523
  * @param {number} code - 编码值
@@ -525,7 +527,7 @@ export declare class Evaluator {
525
527
  */
526
528
  fnCHAR(code: number): string;
527
529
  /**
528
- * 将传入文本转成小写
530
+ * 将传入文本转成小写。
529
531
  *
530
532
  * @example LOWER(text)
531
533
  * @param {string} text - 文本
@@ -535,7 +537,7 @@ export declare class Evaluator {
535
537
  */
536
538
  fnLOWER(text: string): string;
537
539
  /**
538
- * 将传入文本转成大写
540
+ * 将传入文本转成大写。
539
541
  *
540
542
  * @example UPPER(text)
541
543
  * @param {string} text - 文本
@@ -545,7 +547,7 @@ export declare class Evaluator {
545
547
  */
546
548
  fnUPPER(text: string): string;
547
549
  /**
548
- * 将传入文本首字母转成大写
550
+ * 将传入文本首字母转成大写。
549
551
  *
550
552
  * @example UPPERFIRST(text)
551
553
  * @param {string} text - 文本
@@ -555,11 +557,11 @@ export declare class Evaluator {
555
557
  */
556
558
  fnUPPERFIRST(text: string): string;
557
559
  /**
558
- * 向前补齐文本长度
560
+ * 向前补齐文本长度。
559
561
  *
560
- * 示例 `PADSTART("6", 2, "0")`
562
+ * 示例 `PADSTART("6", 2, "0")`,
561
563
  *
562
- * 返回 `06`
564
+ * 返回 `06`。
563
565
  *
564
566
  * @example PADSTART(text)
565
567
  * @param {string} text - 文本
@@ -571,11 +573,11 @@ export declare class Evaluator {
571
573
  */
572
574
  fnPADSTART(text: string, num: number, pad: string): string;
573
575
  /**
574
- * 将文本转成标题
576
+ * 将文本转成标题。
575
577
  *
576
- * 示例 `CAPITALIZE("star")`
578
+ * 示例 `CAPITALIZE("star")`,
577
579
  *
578
- * 返回 `Star`
580
+ * 返回 `Star`。
579
581
  *
580
582
  * @example CAPITALIZE(text)
581
583
  * @param {string} text - 文本
@@ -585,11 +587,11 @@ export declare class Evaluator {
585
587
  */
586
588
  fnCAPITALIZE(text: string): string;
587
589
  /**
588
- * 对文本进行 HTML 转义
590
+ * 对文本进行 HTML 转义。
589
591
  *
590
- * 示例 `ESCAPE("<star>&")`
592
+ * 示例 `ESCAPE("<star>&")`,
591
593
  *
592
- * 返回 `&lt;start&gt;&amp;`
594
+ * 返回 `&lt;start&gt;&amp;`。
593
595
  *
594
596
  * @example ESCAPE(text)
595
597
  * @param {string} text - 文本
@@ -599,11 +601,11 @@ export declare class Evaluator {
599
601
  */
600
602
  fnESCAPE(text: string): string;
601
603
  /**
602
- * 对文本长度进行截断
604
+ * 对文本长度进行截断。
603
605
  *
604
- * 示例 `TRUNCATE("amis.baidu.com", 6)`
606
+ * 示例 `TRUNCATE("amis.baidu.com", 6)`,
605
607
  *
606
- * 返回 `amis...`
608
+ * 返回 `amis...`。
607
609
  *
608
610
  * @example TRUNCATE(text, 6)
609
611
  * @param {string} text - 文本
@@ -614,7 +616,7 @@ export declare class Evaluator {
614
616
  */
615
617
  fnTRUNCATE(text: string, length: number): string;
616
618
  /**
617
- * 取在某个分隔符之前的所有字符串
619
+ * 取在某个分隔符之前的所有字符串。
618
620
  *
619
621
  * @example BEFORELAST(text, '.')
620
622
  * @param {string} text - 文本
@@ -625,11 +627,11 @@ export declare class Evaluator {
625
627
  */
626
628
  fnBEFORELAST(text: string, delimiter?: string): string;
627
629
  /**
628
- * 将文本根据指定片段分割成数组
630
+ * 将文本根据指定片段分割成数组。
629
631
  *
630
- * 示例:`SPLIT("a,b,c", ",")`
632
+ * 示例:`SPLIT("a,b,c", ",")`,
631
633
  *
632
- * 返回 `["a", "b", "c"]`
634
+ * 返回 `["a", "b", "c"]`。
633
635
  *
634
636
  * @example SPLIT(text, ',')
635
637
  * @param {string} text - 文本
@@ -640,7 +642,7 @@ export declare class Evaluator {
640
642
  */
641
643
  fnSPLIT(text: string, sep?: string): string[];
642
644
  /**
643
- * 将文本去除前后空格
645
+ * 将文本去除前后空格。
644
646
  *
645
647
  * @example TRIM(text)
646
648
  * @param {string} text - 文本
@@ -650,11 +652,11 @@ export declare class Evaluator {
650
652
  */
651
653
  fnTRIM(text: string): string;
652
654
  /**
653
- * 去除文本中的 HTML 标签
655
+ * 去除文本中的 HTML 标签。
654
656
  *
655
- * 示例:`STRIPTAG("<b>amis</b>")`
657
+ * 示例:`STRIPTAG("<b>amis</b>")`,
656
658
  *
657
- * 返回:`amis`
659
+ * 返回:`amis`。
658
660
  *
659
661
  * @example STRIPTAG(text)
660
662
  * @param {string} text - 文本
@@ -664,11 +666,11 @@ export declare class Evaluator {
664
666
  */
665
667
  fnSTRIPTAG(text: string): string;
666
668
  /**
667
- * 将字符串中的换行转成 HTML `<br>`,用于简单换行的场景
669
+ * 将字符串中的换行转成 HTML `<br>`,用于简单换行的场景。
668
670
  *
669
- * 示例:`LINEBREAK("\n")`
671
+ * 示例:`LINEBREAK("\n")`,
670
672
  *
671
- * 返回:`<br/>`
673
+ * 返回:`<br/>`。
672
674
  *
673
675
  * @example LINEBREAK(text)
674
676
  * @param {string} text - 文本
@@ -678,7 +680,7 @@ export declare class Evaluator {
678
680
  */
679
681
  fnLINEBREAK(text: string): string;
680
682
  /**
681
- * 判断字符串(text)是否以特定字符串(startString)开始,是则返回 True,否则返回 False
683
+ * 判断字符串(text)是否以特定字符串(startString)开始,是则返回 true,否则返回 false。
682
684
  *
683
685
  * @example STARTSWITH(text, '片段')
684
686
  * @param {string} text - 文本
@@ -689,7 +691,7 @@ export declare class Evaluator {
689
691
  */
690
692
  fnSTARTSWITH(text: string, search: string): boolean;
691
693
  /**
692
- * 判断字符串(text)是否以特定字符串(endString)结束,是则返回 True,否则返回 False
694
+ * 判断字符串(text)是否以特定字符串(endString)结束,是则返回 true,否则返回 false。
693
695
  *
694
696
  * @example ENDSWITH(text, '片段')
695
697
  * @param {string} text - 文本
@@ -700,7 +702,7 @@ export declare class Evaluator {
700
702
  */
701
703
  fnENDSWITH(text: string, search: string): boolean;
702
704
  /**
703
- * 判断参数 1 中的文本是否包含参数 2 中的文本。
705
+ * 判断参数 1 中的文本是否包含参数 2 中的文本,是则返回 true,否则返回 false。
704
706
  *
705
707
  * @example CONTAINS(text, searchText)
706
708
  * @param {string} text - 文本
@@ -723,7 +725,7 @@ export declare class Evaluator {
723
725
  */
724
726
  fnREPLACE(text: string, search: string, replace: string): string;
725
727
  /**
726
- * 对文本进行搜索,返回命中的位置
728
+ * 对文本进行搜索,返回命中的位置。
727
729
  *
728
730
  * @example SEARCH(text, search, 0)
729
731
  * @param {string} text - 要处理的文本
@@ -735,7 +737,7 @@ export declare class Evaluator {
735
737
  */
736
738
  fnSEARCH(text: string, search: string, start?: number): number;
737
739
  /**
738
- * 返回文本字符串中从指定位置开始的特定数目的字符
740
+ * 返回文本字符串中从指定位置开始的特定数目的字符。
739
741
  *
740
742
  * @example MID(text, from, len)
741
743
  * @param {string} text - 要处理的文本
@@ -747,11 +749,11 @@ export declare class Evaluator {
747
749
  */
748
750
  fnMID(text: string, from: number, len: number): string;
749
751
  /**
750
- * 返回路径中的文件名
752
+ * 返回路径中的文件名。
751
753
  *
752
- * 示例:`/home/amis/a.json`
754
+ * 示例:`/home/amis/a.json`,
753
755
  *
754
- * 返回:a.json`
756
+ * 返回:a.json`。
755
757
  *
756
758
  * @example BASENAME(text)
757
759
  * @param {string} text - 要处理的文本
@@ -763,8 +765,8 @@ export declare class Evaluator {
763
765
  /**
764
766
  * 创建日期对象,可以通过特定格式的字符串,或者数值。
765
767
  *
766
- * 需要注意的是,其中月份的数值是从0开始的,也就是说,
767
- * 如果是12月份,你应该传入数值11。
768
+ * 需要注意的是,其中月份的数值是从0开始的,
769
+ * 即如果是12月份,你应该传入数值11。
768
770
  *
769
771
  * @example DATE(2021, 11, 6, 8, 20, 0)
770
772
  * @example DATE('2021-12-06 08:20:00')
@@ -774,10 +776,9 @@ export declare class Evaluator {
774
776
  */
775
777
  fnDATE(year: number, month: number, day: number, hour: number, minute: number, second: number): Date;
776
778
  /**
777
- * 返回时间的时间戳
779
+ * 返回时间的时间戳。
778
780
  *
779
781
  * @example TIMESTAMP(date[, format = "X"])
780
- * @example TIMESTAMP(date, 'x')
781
782
  * @namespace 日期函数
782
783
  * @param {date} date 日期对象
783
784
  * @param {string} format 时间戳格式,带毫秒传入 'x'。默认为 'X' 不带毫秒的。
@@ -786,7 +787,7 @@ export declare class Evaluator {
786
787
  */
787
788
  fnTIMESTAMP(date: Date, format?: 'x' | 'X'): number;
788
789
  /**
789
- * 返回今天的日期
790
+ * 返回今天的日期。
790
791
  *
791
792
  * @example TODAY()
792
793
  * @namespace 日期函数
@@ -804,11 +805,11 @@ export declare class Evaluator {
804
805
  */
805
806
  fnNOW(): Date;
806
807
  /**
807
- * 获取日期的星期几,
808
+ * 获取日期的星期几。
808
809
  *
809
- * 示例:
810
+ * 示例
810
811
  *
811
- * WEEKDAY('2023-02-27') 得到 1
812
+ * WEEKDAY('2023-02-27') 得到 1
812
813
  *
813
814
  * @example WEEKDAY(date)
814
815
  * @namespace 日期函数
@@ -819,11 +820,11 @@ export declare class Evaluator {
819
820
  */
820
821
  fnWEEKDAY(date: Date | string | number, type?: number): number;
821
822
  /**
822
- * 获取年份的星期,即第几周
823
+ * 获取年份的星期,即第几周。
823
824
  *
824
- * 示例:
825
+ * 示例
825
826
  *
826
- * WEEK('2023-03-05') 得到 10
827
+ * WEEK('2023-03-05') 得到 10
827
828
  *
828
829
  * @example WEEK(date)
829
830
  * @namespace 日期函数
@@ -834,14 +835,14 @@ export declare class Evaluator {
834
835
  */
835
836
  fnWEEK(date: Date | string | number, isISO?: boolean): number;
836
837
  /**
837
- * 对日期、日期字符串、时间戳进行格式化
838
+ * 对日期、日期字符串、时间戳进行格式化。
838
839
  *
839
- * 示例:
840
+ * 示例
840
841
  *
841
- * DATETOSTR('12/25/2022', 'YYYY-MM-DD') 得到 '2022.12.25'
842
- * DATETOSTR(1676563200, 'YYYY.MM.DD') 得到 '2023.02.17'
843
- * DATETOSTR(1676563200000, 'YYYY.MM.DD hh:mm:ss') 得到 '2023.02.17 12:00:00'
844
- * DATETOSTR(DATE('2021-12-21'), 'YYYY.MM.DD hh:mm:ss') 得到 '2021.12.21 08:00:00'
842
+ * DATETOSTR('12/25/2022', 'YYYY-MM-DD') 得到 '2022.12.25'
843
+ * DATETOSTR(1676563200, 'YYYY.MM.DD') 得到 '2023.02.17'
844
+ * DATETOSTR(1676563200000, 'YYYY.MM.DD hh:mm:ss') 得到 '2023.02.17 12:00:00'
845
+ * DATETOSTR(DATE('2021-12-21'), 'YYYY.MM.DD hh:mm:ss') 得到 '2021.12.21 08:00:00'
845
846
  *
846
847
  * @example DATETOSTR(date, 'YYYY-MM-DD')
847
848
  * @namespace 日期函数
@@ -852,16 +853,16 @@ export declare class Evaluator {
852
853
  */
853
854
  fnDATETOSTR(date: Date | string | number, format?: string): string;
854
855
  /**
855
- * 获取日期范围字符串中的开始时间、结束时间
856
+ * 获取日期范围字符串中的开始时间、结束时间。
856
857
  *
857
858
  * 示例:
858
859
  *
859
- * DATERANGESPLIT('1676563200, 1676735999') 得到 [1676563200, 1676735999]
860
- * DATERANGESPLIT('1676563200, 1676735999', undefined , 'YYYY.MM.DD hh:mm:ss') 得到 [2023.02.17 12:00:00, 2023.02.18 11:59:59]
861
- * DATERANGESPLIT('1676563200, 1676735999', 0 , 'YYYY.MM.DD hh:mm:ss') 得到 '2023.02.17 12:00:00'
862
- * DATERANGESPLIT('1676563200, 1676735999', 'start' , 'YYYY.MM.DD hh:mm:ss') 得到 '2023.02.17 12:00:00'
863
- * DATERANGESPLIT('1676563200, 1676735999', 1 , 'YYYY.MM.DD hh:mm:ss') 得到 '2023.02.18 11:59:59'
864
- * DATERANGESPLIT('1676563200, 1676735999', 'end' , 'YYYY.MM.DD hh:mm:ss') 得到 '2023.02.18 11:59:59'
860
+ * DATERANGESPLIT('1676563200, 1676735999') 得到 [1676563200, 1676735999]
861
+ * DATERANGESPLIT('1676563200, 1676735999', undefined , 'YYYY.MM.DD hh:mm:ss') 得到 [2023.02.17 12:00:00, 2023.02.18 11:59:59]
862
+ * DATERANGESPLIT('1676563200, 1676735999', 0 , 'YYYY.MM.DD hh:mm:ss') 得到 '2023.02.17 12:00:00'
863
+ * DATERANGESPLIT('1676563200, 1676735999', 'start' , 'YYYY.MM.DD hh:mm:ss') 得到 '2023.02.17 12:00:00'
864
+ * DATERANGESPLIT('1676563200, 1676735999', 1 , 'YYYY.MM.DD hh:mm:ss') 得到 '2023.02.18 11:59:59'
865
+ * DATERANGESPLIT('1676563200, 1676735999', 'end' , 'YYYY.MM.DD hh:mm:ss') 得到 '2023.02.18 11:59:59'
865
866
  *
866
867
  * @example DATERANGESPLIT(date, 'YYYY-MM-DD')
867
868
  * @namespace 日期函数
@@ -874,7 +875,7 @@ export declare class Evaluator {
874
875
  */
875
876
  fnDATERANGESPLIT(daterange: string, key?: string, format?: string, delimiter?: string): string | string[];
876
877
  /**
877
- * 返回日期的指定范围的开端
878
+ * 返回日期的指定范围的开端。
878
879
  *
879
880
  * @namespace 日期函数
880
881
  * @example STARTOF(date[unit = "day"])
@@ -885,7 +886,8 @@ export declare class Evaluator {
885
886
  */
886
887
  fnSTARTOF(date: Date, unit?: any, format?: string): string | Date;
887
888
  /**
888
- * 返回日期的指定范围的末尾
889
+ * 返回日期的指定范围的末尾。
890
+ *
889
891
  * @namespace 日期函数
890
892
  * @example ENDOF(date[unit = "day"])
891
893
  * @param {date} date 日期对象
@@ -897,7 +899,8 @@ export declare class Evaluator {
897
899
  normalizeDate(raw: any): Date;
898
900
  normalizeDateRange(raw: string | Date[]): Date[];
899
901
  /**
900
- * 返回日期的年份
902
+ * 返回日期的年份。
903
+ *
901
904
  * @namespace 日期函数
902
905
  * @example YEAR(date)
903
906
  * @param {date} date 日期对象
@@ -914,7 +917,8 @@ export declare class Evaluator {
914
917
  */
915
918
  fnMONTH(date: Date): number;
916
919
  /**
917
- * 返回日期的天
920
+ * 返回日期的天。
921
+ *
918
922
  * @namespace 日期函数
919
923
  * @example DAY(date)
920
924
  * @param {date} date 日期对象
@@ -922,7 +926,8 @@ export declare class Evaluator {
922
926
  */
923
927
  fnDAY(date: Date): number;
924
928
  /**
925
- * 返回日期的小时
929
+ * 返回日期的小时。
930
+ *
926
931
  * @param {date} date 日期对象
927
932
  * @namespace 日期函数
928
933
  * @example HOUR(date)
@@ -930,7 +935,8 @@ export declare class Evaluator {
930
935
  */
931
936
  fnHOUR(date: Date): number;
932
937
  /**
933
- * 返回日期的分
938
+ * 返回日期的分。
939
+ *
934
940
  * @param {date} date 日期对象
935
941
  * @namespace 日期函数
936
942
  * @example MINUTE(date)
@@ -938,7 +944,8 @@ export declare class Evaluator {
938
944
  */
939
945
  fnMINUTE(date: Date): number;
940
946
  /**
941
- * 返回日期的秒
947
+ * 返回日期的秒。
948
+ *
942
949
  * @param {date} date 日期对象
943
950
  * @namespace 日期函数
944
951
  * @example SECOND(date)
@@ -946,7 +953,8 @@ export declare class Evaluator {
946
953
  */
947
954
  fnSECOND(date: Date): number;
948
955
  /**
949
- * 返回两个日期相差多少年
956
+ * 返回两个日期相差多少年。
957
+ *
950
958
  * @param {date} endDate 日期对象
951
959
  * @param {date} startDate 日期对象
952
960
  * @namespace 日期函数
@@ -955,7 +963,8 @@ export declare class Evaluator {
955
963
  */
956
964
  fnYEARS(endDate: Date, startDate: Date): number;
957
965
  /**
958
- * 返回两个日期相差多少分钟
966
+ * 返回两个日期相差多少分钟。
967
+ *
959
968
  * @param {date} endDate 日期对象
960
969
  * @param {date} startDate 日期对象
961
970
  * @namespace 日期函数
@@ -964,7 +973,8 @@ export declare class Evaluator {
964
973
  */
965
974
  fnMINUTES(endDate: Date, startDate: Date): number;
966
975
  /**
967
- * 返回两个日期相差多少天
976
+ * 返回两个日期相差多少天。
977
+ *
968
978
  * @param {date} endDate 日期对象
969
979
  * @param {date} startDate 日期对象
970
980
  * @namespace 日期函数
@@ -973,7 +983,8 @@ export declare class Evaluator {
973
983
  */
974
984
  fnDAYS(endDate: Date, startDate: Date): number;
975
985
  /**
976
- * 返回两个日期相差多少小时
986
+ * 返回两个日期相差多少小时。
987
+ *
977
988
  * @param {date} endDate 日期对象
978
989
  * @param {date} startDate 日期对象
979
990
  * @namespace 日期函数
@@ -982,11 +993,11 @@ export declare class Evaluator {
982
993
  */
983
994
  fnHOURS(endDate: Date, startDate: Date): number;
984
995
  /**
985
- * 修改日期,对日期进行加减天、月份、年等操作
996
+ * 修改日期,对日期进行加减天、月份、年等操作。
986
997
  *
987
998
  * 示例:
988
999
  *
989
- * DATEMODIFY(A, -2, 'month')
1000
+ * DATEMODIFY(A, -2, 'month')
990
1001
  *
991
1002
  * 对日期 A 进行往前减2月的操作。
992
1003
  *
@@ -1011,7 +1022,7 @@ export declare class Evaluator {
1011
1022
  */
1012
1023
  fnSTRTODATE(value: any, format?: string): Date;
1013
1024
  /**
1014
- * 判断两个日期,是否第一个日期在第二个日期的前面
1025
+ * 判断两个日期,是否第一个日期在第二个日期的前面,是则返回 true,否则返回 false。
1015
1026
  *
1016
1027
  * @param {date} a 第一个日期
1017
1028
  * @param {date} b 第二个日期
@@ -1022,7 +1033,7 @@ export declare class Evaluator {
1022
1033
  */
1023
1034
  fnISBEFORE(a: Date, b: Date, unit?: any): boolean;
1024
1035
  /**
1025
- * 判断两个日期,是否第一个日期在第二个日期的后面
1036
+ * 判断两个日期,是否第一个日期在第二个日期的后面,是则返回 true,否则返回 false。
1026
1037
  *
1027
1038
  * @param {date} a 第一个日期
1028
1039
  * @param {date} b 第二个日期
@@ -1033,9 +1044,9 @@ export declare class Evaluator {
1033
1044
  */
1034
1045
  fnISAFTER(a: Date, b: Date, unit?: any): boolean;
1035
1046
  /**
1036
- * 判断日期是否在指定范围内
1047
+ * 判断日期是否在指定范围内,是则返回 true,否则返回 false。
1037
1048
  *
1038
- * 示例:BETWEENRANGE('2021/12/6', ['2021/12/5','2021/12/7'])
1049
+ * 示例:BETWEENRANGE('2021/12/6', ['2021/12/5','2021/12/7'])
1039
1050
  *
1040
1051
  * @param {any} date 第一个日期
1041
1052
  * @param {any[]} daterange 日期范围
@@ -1047,7 +1058,7 @@ export declare class Evaluator {
1047
1058
  */
1048
1059
  fnBETWEENRANGE(date: Date, daterange: Date[], unit?: any, inclusivity?: '[]' | '()' | '(]' | '[)'): boolean;
1049
1060
  /**
1050
- * 判断两个日期,是否第一个日期在第二个日期的前面或者相等
1061
+ * 判断两个日期,是否第一个日期在第二个日期的前面或者相等,是则返回 true,否则返回 false。
1051
1062
  *
1052
1063
  * @param {date} a 第一个日期
1053
1064
  * @param {date} b 第二个日期
@@ -1058,7 +1069,7 @@ export declare class Evaluator {
1058
1069
  */
1059
1070
  fnISSAMEORBEFORE(a: Date, b: Date, unit?: any): boolean;
1060
1071
  /**
1061
- * 判断两个日期,是否第一个日期在第二个日期的后面或者相等
1072
+ * 判断两个日期,是否第一个日期在第二个日期的后面或者相等,是则返回 true,否则返回 false。
1062
1073
  *
1063
1074
  * @param {date} a 第一个日期
1064
1075
  * @param {date} b 第二个日期
@@ -1069,7 +1080,7 @@ export declare class Evaluator {
1069
1080
  */
1070
1081
  fnISSAMEORAFTER(a: Date, b: Date, unit?: any): boolean;
1071
1082
  /**
1072
- * 返回数组的长度
1083
+ * 返回数组的长度。
1073
1084
  *
1074
1085
  * @param {Array<any>} arr 数组
1075
1086
  * @namespace 数组
@@ -1104,7 +1115,7 @@ export declare class Evaluator {
1104
1115
  *
1105
1116
  * 示例:
1106
1117
  *
1107
- * ARRAYFINDINDEX([0, 2, false], item => item === 2) 得到 1
1118
+ * ARRAYFINDINDEX([0, 2, false], item => item === 2) 得到 1
1108
1119
  *
1109
1120
  * @param {Array<any>} arr 数组
1110
1121
  * @param {Function<any>} iterator 箭头函数
@@ -1119,7 +1130,7 @@ export declare class Evaluator {
1119
1130
  *
1120
1131
  * 示例:
1121
1132
  *
1122
- * ARRAYFIND([0, 2, false], item => item === 2) 得到 2
1133
+ * ARRAYFIND([0, 2, false], item => item === 2) 得到 2
1123
1134
  *
1124
1135
  * @param {Array<any>} arr 数组
1125
1136
  * @param {Function<any>} iterator 箭头函数
@@ -1130,11 +1141,11 @@ export declare class Evaluator {
1130
1141
  fnARRAYFIND(arr: any[], iterator: any): any;
1131
1142
  /**
1132
1143
  * 数据做数据遍历判断,需要搭配箭头函数一起使用,注意箭头函数只支持单表达式用法。
1133
- * 判断第二个箭头函数是否存在返回为 true 的成员。
1144
+ * 判断第二个箭头函数是否存在返回为 true 的成员,是则返回 true,否则返回 false。
1134
1145
  *
1135
1146
  * 示例:
1136
1147
  *
1137
- * ARRAYSOME([0, 2, false], item => item === 2) 得到 true
1148
+ * ARRAYSOME([0, 2, false], item => item === 2) 得到 true
1138
1149
  *
1139
1150
  * @param {Array<any>} arr 数组
1140
1151
  * @param {Function<any>} iterator 箭头函数
@@ -1145,7 +1156,7 @@ export declare class Evaluator {
1145
1156
  fnARRAYSOME(arr: any[], iterator: any): boolean;
1146
1157
  /**
1147
1158
  * 数据做数据遍历判断,需要搭配箭头函数一起使用,注意箭头函数只支持单表达式用法。
1148
- * 判断第二个箭头函数返回是否都为 true。
1159
+ * 判断第二个箭头函数返回是否都为 true,是则返回 true,否则返回 false
1149
1160
  *
1150
1161
  * 示例:
1151
1162
  *
@@ -1159,11 +1170,11 @@ export declare class Evaluator {
1159
1170
  */
1160
1171
  fnARRAYEVERY(arr: any[], iterator: any): boolean;
1161
1172
  /**
1162
- * 判断数据中是否存在指定元素
1173
+ * 判断数据中是否存在指定元素。
1163
1174
  *
1164
1175
  * 示例:
1165
1176
  *
1166
- * ARRAYINCLUDES([0, 2, false], 2) 得到 true
1177
+ * ARRAYINCLUDES([0, 2, false], 2) 得到 true
1167
1178
  *
1168
1179
  * @param {Array<any>} arr 数组
1169
1180
  * @param {any} item 元素
@@ -1173,11 +1184,11 @@ export declare class Evaluator {
1173
1184
  */
1174
1185
  fnARRAYINCLUDES(arr: any[], item: any): boolean;
1175
1186
  /**
1176
- * 数组过滤掉 false、null、0 和 ""
1187
+ * 数组过滤掉 false、null、0 和 ""
1177
1188
  *
1178
1189
  * 示例:
1179
1190
  *
1180
- * COMPACT([0, 1, false, 2, '', 3]) 得到 [1, 2, 3]
1191
+ * COMPACT([0, 1, false, 2, '', 3]) 得到 [1, 2, 3]
1181
1192
  *
1182
1193
  * @param {Array<any>} arr 数组
1183
1194
  * @namespace 数组
@@ -1186,11 +1197,11 @@ export declare class Evaluator {
1186
1197
  */
1187
1198
  fnCOMPACT(arr: any[]): any[];
1188
1199
  /**
1189
- * 数组转成字符串
1200
+ * 数组转成字符串。
1190
1201
  *
1191
1202
  * 示例:
1192
1203
  *
1193
- * JOIN(['a', 'b', 'c'], '=') 得到 'a=b=c'
1204
+ * JOIN(['a', 'b', 'c'], '=') 得到 'a=b=c'
1194
1205
  *
1195
1206
  * @param {Array<any>} arr 数组
1196
1207
  * @param { String} separator 分隔符
@@ -1200,11 +1211,11 @@ export declare class Evaluator {
1200
1211
  */
1201
1212
  fnJOIN(arr: any[], separator?: string): string;
1202
1213
  /**
1203
- * 数组合并
1214
+ * 数组合并。
1204
1215
  *
1205
1216
  * 示例:
1206
1217
  *
1207
- * CONCAT(['a', 'b', 'c'], ['1'], ['3']) 得到 ['a', 'b', 'c', '1', '3']
1218
+ * CONCAT(['a', 'b', 'c'], ['1'], ['3']) 得到 ['a', 'b', 'c', '1', '3']
1208
1219
  *
1209
1220
  * @param {Array<any>} arr 数组
1210
1221
  * @namespace 数组
@@ -1213,11 +1224,11 @@ export declare class Evaluator {
1213
1224
  */
1214
1225
  fnCONCAT(...arr: any[]): any;
1215
1226
  /**
1216
- * 数组去重,第二个参数「field」,可指定根据该字段去重
1227
+ * 数组去重,第二个参数「field」,可指定根据该字段去重。
1217
1228
  *
1218
1229
  * 示例:
1219
1230
  *
1220
- * UNIQ([{a: '1'}, {b: '2'}, {a: '1'}], 'id')
1231
+ * UNIQ([{a: '1'}, {b: '2'}, {a: '1'}], 'id')
1221
1232
  *
1222
1233
  * @param {Array<any>} arr 数组
1223
1234
  * @param {string} field 字段
@@ -1228,11 +1239,11 @@ export declare class Evaluator {
1228
1239
  */
1229
1240
  fnUNIQ(arr: any[], field?: string): any[];
1230
1241
  /**
1231
- * 将JS对象转换成JSON字符串
1242
+ * 将JS对象转换成JSON字符串。
1232
1243
  *
1233
1244
  * 示例:
1234
1245
  *
1235
- * ENCODEJSON({name: 'amis'}) 得到 '{"name":"amis"}'
1246
+ * ENCODEJSON({name: 'amis'}) 得到 '{"name":"amis"}'
1236
1247
  *
1237
1248
  * @param {object} obj JS对象
1238
1249
  * @namespace 编码
@@ -1241,11 +1252,11 @@ export declare class Evaluator {
1241
1252
  */
1242
1253
  fnENCODEJSON(obj: object): string;
1243
1254
  /**
1244
- * 解析JSON编码数据,返回JS对象
1255
+ * 解析JSON编码数据,返回JS对象。
1245
1256
  *
1246
1257
  * 示例:
1247
1258
  *
1248
- * DECODEJSON('{\"name\": "amis"}') 得到 {name: 'amis'}
1259
+ * DECODEJSON('{\"name\": "amis"}') 得到 {name: 'amis'}
1249
1260
  *
1250
1261
  * @param {string} str 字符串
1251
1262
  * @namespace 编码
@@ -1254,15 +1265,15 @@ export declare class Evaluator {
1254
1265
  */
1255
1266
  fnDECODEJSON(str: string): object;
1256
1267
  /**
1257
- * 根据对象或者数组的path路径获取值。 如果解析 value 是 undefined 会以 defaultValue 取代
1268
+ * 根据对象或者数组的path路径获取值。 如果解析 value 是 undefined 会以 defaultValue 取代。
1258
1269
  *
1259
1270
  * 示例:
1260
1271
  *
1261
- * GET([0, 2, {name: 'amis', age: 18}], 1) 得到 2
1262
- * GET([0, 2, {name: 'amis', age: 18}], '2.name') 得到 'amis'
1263
- * GET({arr: [{name: 'amis', age: 18}]}, 'arr[0].name') 得到 'amis'
1264
- * GET({arr: [{name: 'amis', age: 18}]}, 'arr.0.name') 得到 'amis'
1265
- * GET({arr: [{name: 'amis', age: 18}]}, 'arr.1.name', 'not-found') 得到 'not-found'
1272
+ * GET([0, 2, {name: 'amis', age: 18}], 1) 得到 2
1273
+ * GET([0, 2, {name: 'amis', age: 18}], '2.name') 得到 'amis'
1274
+ * GET({arr: [{name: 'amis', age: 18}]}, 'arr[0].name') 得到 'amis'
1275
+ * GET({arr: [{name: 'amis', age: 18}]}, 'arr.0.name') 得到 'amis'
1276
+ * GET({arr: [{name: 'amis', age: 18}]}, 'arr.1.name', 'not-found') 得到 'not-found'
1266
1277
  *
1267
1278
  * @param {any} obj 对象或数组
1268
1279
  * @param {string} path 路径