util-helpers 4.16.0 → 4.16.1
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/dist/util-helpers.js +60 -46
- package/dist/util-helpers.js.map +1 -1
- package/dist/util-helpers.min.js +1 -1
- package/dist/util-helpers.min.js.map +1 -1
- package/esm/blobToDataURL.js +2 -2
- package/esm/calculateCursorPosition.js +2 -2
- package/esm/dataURLToBlob.js +1 -1
- package/esm/download.js +31 -16
- package/esm/fileReader.js +2 -2
- package/esm/index.js +2 -2
- package/esm/interface.doc.js +3 -2
- package/esm/isBankCard.js +1 -1
- package/esm/isBusinessLicense.js +1 -1
- package/esm/isChinese.js +3 -3
- package/esm/isHMCard.js +1 -1
- package/esm/isIdCard.js +2 -2
- package/esm/isPassport.js +1 -1
- package/esm/isPassword.js +2 -2
- package/esm/isSocialCreditCode.js +1 -1
- package/esm/isSwiftCode.js +1 -1
- package/esm/isTWCard.js +1 -1
- package/esm/isUrl.js +1 -1
- package/esm/isVehicle.js +1 -1
- package/esm/normalizeString.js +1 -1
- package/esm/parseIdCard.js +1 -1
- package/esm/safeDate.js +1 -1
- package/esm/setDataURLPrefix.js +2 -2
- package/esm/utils/config.js +1 -1
- package/esm/validatePassword.js +1 -1
- package/lib/blobToDataURL.js +2 -2
- package/lib/calculateCursorPosition.js +2 -2
- package/lib/dataURLToBlob.js +1 -1
- package/lib/download.js +31 -16
- package/lib/fileReader.js +2 -2
- package/lib/interface.doc.js +3 -2
- package/lib/isBankCard.js +1 -1
- package/lib/isBusinessLicense.js +1 -1
- package/lib/isChinese.js +3 -3
- package/lib/isHMCard.js +1 -1
- package/lib/isIdCard.js +2 -2
- package/lib/isPassport.js +1 -1
- package/lib/isPassword.js +2 -2
- package/lib/isSocialCreditCode.js +1 -1
- package/lib/isSwiftCode.js +1 -1
- package/lib/isTWCard.js +1 -1
- package/lib/isUrl.js +1 -1
- package/lib/isVehicle.js +1 -1
- package/lib/normalizeString.js +1 -1
- package/lib/parseIdCard.js +1 -1
- package/lib/safeDate.js +1 -1
- package/lib/setDataURLPrefix.js +2 -2
- package/lib/utils/config.js +1 -1
- package/lib/validatePassword.js +1 -1
- package/package.json +1 -1
- package/types/blobToDataURL.d.ts +2 -2
- package/types/calculateCursorPosition.d.ts +2 -2
- package/types/dataURLToBlob.d.ts +1 -1
- package/types/download.d.ts +6 -5
- package/types/isBankCard.d.ts +1 -1
- package/types/isBusinessLicense.d.ts +1 -1
- package/types/isChinese.d.ts +3 -3
- package/types/isHMCard.d.ts +1 -1
- package/types/isIdCard.d.ts +2 -2
- package/types/isPassport.d.ts +1 -1
- package/types/isPassword.d.ts +2 -2
- package/types/isSocialCreditCode.d.ts +1 -1
- package/types/isSwiftCode.d.ts +1 -1
- package/types/isTWCard.d.ts +1 -1
- package/types/isUrl.d.ts +1 -1
- package/types/isVehicle.d.ts +1 -1
- package/types/normalizeString.d.ts +1 -1
- package/types/parseIdCard.d.ts +1 -1
- package/types/setDataURLPrefix.d.ts +2 -2
- package/types/validatePassword.d.ts +1 -1
package/esm/blobToDataURL.js
CHANGED
|
@@ -9,11 +9,11 @@ import fileReader from "./fileReader";
|
|
|
9
9
|
*
|
|
10
10
|
* <em style="font-weight: bold;">注意:该方法仅适用于浏览器端。</em>
|
|
11
11
|
*
|
|
12
|
+
* @ignore
|
|
12
13
|
* @static
|
|
13
14
|
* @alias module:Processor.blobToDataURL
|
|
14
|
-
* @see 参考 {@link https://developer.mozilla.org/zh-CN/docs/Web/API/FileReader/readAsDataURL|FileReader.readAsDataURL()}
|
|
15
15
|
* @since 4.1.0
|
|
16
|
-
* @
|
|
16
|
+
* @see {@link https://developer.mozilla.org/zh-CN/docs/Web/API/FileReader/readAsDataURL|FileReader.readAsDataURL()}
|
|
17
17
|
* @deprecated 请使用 `fileReader` 方法
|
|
18
18
|
* @param {Blob} blob Blob 或 File 对象
|
|
19
19
|
* @returns {Promise<string>} data:URL 格式的 Base64 字符串。
|
|
@@ -8,8 +8,8 @@ import normalizeString from './normalizeString';
|
|
|
8
8
|
* @static
|
|
9
9
|
* @alias module:Other.calculateCursorPosition
|
|
10
10
|
* @since 4.6.0
|
|
11
|
-
* @see
|
|
12
|
-
* @see
|
|
11
|
+
* @see {@link https://2950v9.csb.app/|h5示例}
|
|
12
|
+
* @see {@link https://33ccy9.csb.app/|react示例}
|
|
13
13
|
* @param {number} prevPos 赋值前的光标位置,onChange/onInput的光标位置 e.target.selectionEnd
|
|
14
14
|
* @param {string} prevCtrlValue 上一个格式化后的值
|
|
15
15
|
* @param {string} rawValue 当前输入原值
|
package/esm/dataURLToBlob.js
CHANGED
|
@@ -3,8 +3,8 @@
|
|
|
3
3
|
*
|
|
4
4
|
* @static
|
|
5
5
|
* @alias module:Processor.dataURLToBlob
|
|
6
|
-
* @see 参考 {@link https://developer.mozilla.org/zh-CN/docs/Glossary/Base64|Base64}
|
|
7
6
|
* @since 4.1.0
|
|
7
|
+
* @see {@link https://developer.mozilla.org/zh-CN/docs/Glossary/Base64|Base64}
|
|
8
8
|
* @param {string} dataurl data: 协议的URL
|
|
9
9
|
* @returns {Blob} Blob 对象
|
|
10
10
|
* @example
|
package/esm/download.js
CHANGED
|
@@ -5,6 +5,7 @@ import dataURLToBlob from "./dataURLToBlob";
|
|
|
5
5
|
import isUrl from "./isUrl";
|
|
6
6
|
import ajax from "./ajax";
|
|
7
7
|
import { isBlob } from "./utils/type";
|
|
8
|
+
import isPromiseLike from "./isPromiseLike";
|
|
8
9
|
|
|
9
10
|
/**
|
|
10
11
|
* 下载文件
|
|
@@ -41,13 +42,13 @@ function saver(blobUrl, fileName) {
|
|
|
41
42
|
/**
|
|
42
43
|
* @callback TransformRequest
|
|
43
44
|
* @param {AjaxOptions} options ajax 配置项
|
|
44
|
-
* @returns {AjaxOptions}
|
|
45
|
+
* @returns {AjaxOptions | Promise<AjaxOptions>}
|
|
45
46
|
*/
|
|
46
47
|
|
|
47
48
|
/**
|
|
48
49
|
* @callback TransformResponse
|
|
49
50
|
* @param {Blob} res 响应的Blob对象。如果你通过 transformRequest 修改了 responseType ,该参数将是该类型响应值。
|
|
50
|
-
* @returns {Blob}
|
|
51
|
+
* @returns {Blob | Promise<Blob>}
|
|
51
52
|
*/
|
|
52
53
|
|
|
53
54
|
/**
|
|
@@ -67,7 +68,8 @@ function saver(blobUrl, fileName) {
|
|
|
67
68
|
* @static
|
|
68
69
|
* @alias module:Other.download
|
|
69
70
|
* @since 4.16.0
|
|
70
|
-
* @see {@link https://zh.wikipedia.org/wiki
|
|
71
|
+
* @see {@link https://zh.wikipedia.org/wiki/多用途互聯網郵件擴展|MIME}
|
|
72
|
+
* @see {@link https://9ykc9s.csb.app/|在线示例}
|
|
71
73
|
* @param {string|Blob|ArrayBuffer|Int8Array|Uint8Array|Uint8ClampedArray|Int16Array|Uint16Array|Int32Array|Uint32Array|Float32Array|Float64Array|BigInt64Array|BigUint64Array} data 字符串、blob数据或url地址
|
|
72
74
|
* @param {string|DownloadOptions} [options] 文件名称 或 配置项
|
|
73
75
|
* @returns {Promise<void>}
|
|
@@ -107,21 +109,34 @@ function download(data, options) {
|
|
|
107
109
|
payload = dataURLToBlob(data);
|
|
108
110
|
} else if (dataType === 'url' || !dataType && isUrl(data)) {
|
|
109
111
|
// url
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
112
|
+
// 包装为异步方法
|
|
113
|
+
/** @type {(opts: AjaxOptions)=>Promise<AjaxOptions>} */
|
|
114
|
+
var asyncTransformRequest = function asyncTransformRequest(opts) {
|
|
115
|
+
// 请求前配置调整
|
|
116
|
+
var tempOptions = typeof transformRequest === 'function' ? transformRequest(opts) : opts;
|
|
117
|
+
// @ts-ignore
|
|
118
|
+
return isPromiseLike(tempOptions) ? tempOptions : Promise.resolve(tempOptions);
|
|
113
119
|
};
|
|
114
|
-
|
|
115
|
-
var
|
|
116
|
-
|
|
117
|
-
/** @type {Blob} */
|
|
120
|
+
/** @type {(res: Blob)=>Promise<Blob>} */
|
|
121
|
+
var asyncTransformResponse = function asyncTransformResponse(res) {
|
|
122
|
+
var tempRes = typeof transformResponse === 'function' ? transformResponse(res) : res;
|
|
118
123
|
// @ts-ignore
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
124
|
+
return isPromiseLike(tempRes) ? tempRes : Promise.resolve(tempRes);
|
|
125
|
+
};
|
|
126
|
+
|
|
127
|
+
// 此处如果使用 async/await 语法糖,编译后的umd代码过大
|
|
128
|
+
return asyncTransformRequest({
|
|
129
|
+
responseType: 'blob'
|
|
130
|
+
}).then(function (ajaxOptions) {
|
|
131
|
+
return ajax(data, ajaxOptions).then(function (e) {
|
|
132
|
+
// @ts-ignore
|
|
133
|
+
return asyncTransformResponse(e.target.response).then(function (res) {
|
|
134
|
+
var currentFileName = fileName || data.split("?")[0].split("#")[0].split("/").pop();
|
|
135
|
+
return download(res, {
|
|
136
|
+
fileName: currentFileName,
|
|
137
|
+
type: type || (isBlob(res) ? res.type : undefined)
|
|
138
|
+
});
|
|
139
|
+
});
|
|
125
140
|
});
|
|
126
141
|
});
|
|
127
142
|
} else {
|
package/esm/fileReader.js
CHANGED
|
@@ -20,13 +20,13 @@ var FileReaderMethodMap = {
|
|
|
20
20
|
*/
|
|
21
21
|
|
|
22
22
|
/**
|
|
23
|
-
* 读取 Blob 或 File
|
|
23
|
+
* 读取 Blob 或 File 对象,可以将 Blob 转为 Base64/String/ArrayBuffer<br/><br/>
|
|
24
24
|
*
|
|
25
25
|
* <em style="font-weight: bold;">注意:该方法仅适用于浏览器端。</em>
|
|
26
26
|
*
|
|
27
27
|
* @static
|
|
28
28
|
* @alias module:Processor.fileReader
|
|
29
|
-
* @see
|
|
29
|
+
* @see {@link https://developer.mozilla.org/zh-CN/docs/Web/API/FileReader|FileReader}
|
|
30
30
|
* @since 4.16.0
|
|
31
31
|
* @param {Blob} blob Blob 或 File 对象
|
|
32
32
|
* @param {'arrayBuffer'|'binaryString'|'dataURL'|'text'} [type='dataURL'] Blob 或 File 对象
|
package/esm/index.js
CHANGED
|
@@ -53,8 +53,8 @@ export { default as padZero } from './padZero';
|
|
|
53
53
|
*
|
|
54
54
|
* @module Math
|
|
55
55
|
* @since 3.1.0
|
|
56
|
-
* @see
|
|
57
|
-
* @see
|
|
56
|
+
* @see {@link https://github.com/camsong/blog/issues/9|JavaScript 浮点数陷阱及解法}
|
|
57
|
+
* @see {@link https://2zbuy.csb.app/|JS浮点数计算测试}
|
|
58
58
|
* @example
|
|
59
59
|
* // 从 4.12.0 版本开始,规范了有效数值。(注意:4.12.3 对有效数值重新定义)
|
|
60
60
|
* // 有效数值即能通过 Number(value) 转为数字,且不能为 NaN 。
|
package/esm/interface.doc.js
CHANGED
|
@@ -80,13 +80,13 @@ function ajax(url, options) {}
|
|
|
80
80
|
/**
|
|
81
81
|
* @callback TransformRequest
|
|
82
82
|
* @param {AjaxOptions} options ajax 配置项
|
|
83
|
-
* @returns {AjaxOptions}
|
|
83
|
+
* @returns {AjaxOptions | Promise<AjaxOptions>}
|
|
84
84
|
*/
|
|
85
85
|
|
|
86
86
|
/**
|
|
87
87
|
* @callback TransformResponse
|
|
88
88
|
* @param {Blob} res 响应的Blob对象。如果你通过 transformRequest 修改了 responseType ,该参数将是该类型响应值。
|
|
89
|
-
* @returns {Blob}
|
|
89
|
+
* @returns {Blob | Promise<Blob>}
|
|
90
90
|
*/
|
|
91
91
|
|
|
92
92
|
/**
|
|
@@ -107,6 +107,7 @@ function ajax(url, options) {}
|
|
|
107
107
|
* @alias module:Other.download
|
|
108
108
|
* @since 4.16.0
|
|
109
109
|
* @see {@link https://zh.wikipedia.org/wiki/多用途互聯網郵件擴展|MIME}
|
|
110
|
+
* @see {@link https://9ykc9s.csb.app/|在线示例}
|
|
110
111
|
* @param {string|Blob|TypedArray} data 字符串、blob数据或url地址
|
|
111
112
|
* @param {string|DownloadOptions} [options] 文件名称 或 配置项
|
|
112
113
|
* @returns {Promise<void>}
|
package/esm/isBankCard.js
CHANGED
|
@@ -28,8 +28,8 @@ function sumCheckCode(numStr) {
|
|
|
28
28
|
*
|
|
29
29
|
* @static
|
|
30
30
|
* @alias module:Validator.isBankCard
|
|
31
|
-
* @see 参考 {@link https://kf.qq.com/faq/170112ABnm6b170112FvquAn.html|常用银行账号位数参考}
|
|
32
31
|
* @since 1.1.0
|
|
32
|
+
* @see {@link https://kf.qq.com/faq/170112ABnm6b170112FvquAn.html|常用银行账号位数参考}
|
|
33
33
|
* @param {*} value 要检测的值
|
|
34
34
|
* @param {Object} [options] 配置项
|
|
35
35
|
* @param {boolean} [options.loose=false] 宽松模式,8~30位数字
|
package/esm/isBusinessLicense.js
CHANGED
|
@@ -38,8 +38,8 @@ function sumCheckCode(preCode) {
|
|
|
38
38
|
*
|
|
39
39
|
* @static
|
|
40
40
|
* @alias module:Validator.isBusinessLicense
|
|
41
|
-
* @see 参考 {@link https://wenku.baidu.com/view/19873704cc1755270722087c.html|GS15—2006 工商行政管理市场主体注册号编制规则}
|
|
42
41
|
* @since 3.5.0
|
|
42
|
+
* @see {@link https://wenku.baidu.com/view/19873704cc1755270722087c.html|GS15—2006 工商行政管理市场主体注册号编制规则}
|
|
43
43
|
* @param {*} value 要检测的值
|
|
44
44
|
* @param {Object} [options] 配置项
|
|
45
45
|
* @param {boolean} [options.checkCode=true] 是否校验最后一位校验码,如果为false,不校验校验位。
|
package/esm/isChinese.js
CHANGED
|
@@ -32,9 +32,9 @@ var supportRegExpUnicode = RegExp.prototype.hasOwnProperty('unicode');
|
|
|
32
32
|
* @static
|
|
33
33
|
* @alias module:Validator.isChinese
|
|
34
34
|
* @since 1.1.0
|
|
35
|
-
* @see
|
|
36
|
-
* @see
|
|
37
|
-
* @see
|
|
35
|
+
* @see {@link http://www.unicode.org/reports/tr38/#BlockListing|4.4 Listing of Characters Covered by the Unihan Database}
|
|
36
|
+
* @see {@link https://zh.wikipedia.org/wiki/Unicode字符平面映射|Unicode字符平面映射}
|
|
37
|
+
* @see {@link https://zh.wikipedia.org/wiki/Unicode區段|Unicode区段}
|
|
38
38
|
* @param {*} value 要检测的值
|
|
39
39
|
* @param {Object} [options] 配置项
|
|
40
40
|
* @param {boolean} [options.loose=false] 宽松模式。如果为true,只要包含中文即为true
|
package/esm/isHMCard.js
CHANGED
|
@@ -9,7 +9,7 @@ var regHMCard = /^[hm]{1}([0-9]{10}|[0-9]{8})$/i;
|
|
|
9
9
|
* @static
|
|
10
10
|
* @alias module:Validator.isHMCard
|
|
11
11
|
* @since 4.0.0
|
|
12
|
-
* @see
|
|
12
|
+
* @see {@link https://zh.wikipedia.org/wiki/港澳居民来往内地通行证|港澳居民来往内地通行证}
|
|
13
13
|
* @param {*} value 要检测的值
|
|
14
14
|
* @returns {boolean} 是否为港澳居民来往内地通行证
|
|
15
15
|
* @example
|
package/esm/isIdCard.js
CHANGED
|
@@ -29,8 +29,8 @@ function check(id) {
|
|
|
29
29
|
* @static
|
|
30
30
|
* @alias module:Validator.isIdCard
|
|
31
31
|
* @since 1.1.0
|
|
32
|
-
* @see
|
|
33
|
-
* @see
|
|
32
|
+
* @see {@link https://zh.wikipedia.org/wiki/中华人民共和国公民身份号码|中华人民共和国公民身份号码}
|
|
33
|
+
* @see {@link https://baike.baidu.com/item/居民身份证号码|居民身份证号码}
|
|
34
34
|
* @param {*} value 要检测的值
|
|
35
35
|
* @param {Object} [options] 配置项
|
|
36
36
|
* @param {boolean} [options.loose=false] 宽松模式,支持15位身份证号码
|
package/esm/isPassport.js
CHANGED
|
@@ -9,8 +9,8 @@ var reg = /^((e[\da-z])|(de)|(se)|(pe)|([khm][\da-z]))[\da-z]{7}$/i;
|
|
|
9
9
|
*
|
|
10
10
|
* @static
|
|
11
11
|
* @alias module:Validator.isPassport
|
|
12
|
-
* @see 参考 {@link https://zh.wikipedia.org/wiki/中华人民共和国护照#个人资料页|中华人民共和国护照#个人资料页}
|
|
13
12
|
* @since 1.1.0
|
|
13
|
+
* @see {@link https://zh.wikipedia.org/wiki/中华人民共和国护照#个人资料页|中华人民共和国护照#个人资料页}
|
|
14
14
|
* @param {*} value 要检测的值
|
|
15
15
|
* @returns {boolean} 值是否为护照号
|
|
16
16
|
* @example
|
package/esm/isPassword.js
CHANGED
|
@@ -5,11 +5,11 @@ import validatePassword from './validatePassword';
|
|
|
5
5
|
* <p><strong>注意:该校验只校验是否存在不同字符(大小写字母、数字、特殊符号),不判断长度。</strong></p>
|
|
6
6
|
* <p><i>如果需要更细致的验证,请使用 <a href="#.validatePassword">validatePassword</a></i></p>
|
|
7
7
|
*
|
|
8
|
-
* @see 参考 {@link https://baike.baidu.com/item/ASCII#3|ASCII}
|
|
9
8
|
* @static
|
|
10
9
|
* @alias module:Validator.isPassword
|
|
11
|
-
* @since 1.1.0
|
|
12
10
|
* @requires module:Validator.validatePassword
|
|
11
|
+
* @since 1.1.0
|
|
12
|
+
* @see {@link https://baike.baidu.com/item/ASCII#3|ASCII}
|
|
13
13
|
* @param {*} value 要检测的值
|
|
14
14
|
* @param {Object} [options] 配置项
|
|
15
15
|
* @param {number} [options.level=2] 密码强度 1-包含一种字符 2-包含两种字符 3-包含三种字符。(大写字母、小写字母、数字、特殊字符)
|
|
@@ -44,8 +44,8 @@ function sumCheckCode(preCode) {
|
|
|
44
44
|
*
|
|
45
45
|
* @static
|
|
46
46
|
* @alias module:Validator.isSocialCreditCode
|
|
47
|
-
* @see 参考 {@link https://zh.wikisource.org/zh-hans/GB_32100-2015_法人和其他组织统一社会信用代码编码规则|GB 32100-2015 法人和其他组织统一社会信用代码编码规则}
|
|
48
47
|
* @since 1.1.0
|
|
48
|
+
* @see {@link https://zh.wikisource.org/zh-hans/GB_32100-2015_法人和其他组织统一社会信用代码编码规则|GB 32100-2015 法人和其他组织统一社会信用代码编码规则}
|
|
49
49
|
* @param {*} value 要检测的值
|
|
50
50
|
* @param {Object} [options] 配置项
|
|
51
51
|
* @param {boolean} [options.checkCode=true] 是否校验最后一位校验码,如果为false,不校验校验位。
|
package/esm/isSwiftCode.js
CHANGED
|
@@ -6,8 +6,8 @@ var reg = /^[A-Z]{6}[A-Z\d]{2}(?:[A-Z\d]{3})?$/;
|
|
|
6
6
|
*
|
|
7
7
|
* @static
|
|
8
8
|
* @alias module:Validator.isSwiftCode
|
|
9
|
-
* @see 参考 {@link https://zh.wikipedia.org/wiki/ISO_9362|ISO 9362}
|
|
10
9
|
* @since 4.9.0
|
|
10
|
+
* @see {@link https://zh.wikipedia.org/wiki/ISO_9362|ISO 9362}
|
|
11
11
|
* @param {*} value 要检测的值
|
|
12
12
|
* @returns {boolean} 值是否为 Swift Code
|
|
13
13
|
* @example
|
package/esm/isTWCard.js
CHANGED
|
@@ -12,7 +12,7 @@ var singleRegTWCard = /^[\da-z]{10,12}$/i;
|
|
|
12
12
|
* @static
|
|
13
13
|
* @alias module:Validator.isTWCard
|
|
14
14
|
* @since 4.0.0
|
|
15
|
-
* @see
|
|
15
|
+
* @see {@link https://zh.wikipedia.org/wiki/台湾居民来往大陆通行证|台湾居民来往大陆通行证}
|
|
16
16
|
* @param {*} value 要检测的值
|
|
17
17
|
* @param {Object} [options] 配置项
|
|
18
18
|
* @param {boolean} [options.loose=false] 宽松模式。如果为true,表示支持一次性短期通行证
|
package/esm/isUrl.js
CHANGED
|
@@ -24,7 +24,7 @@ var regNonProtocal = new RegExp("^(?:".concat(serverReg, ")(?:").concat(portReg,
|
|
|
24
24
|
* @static
|
|
25
25
|
* @alias module:Validator.isUrl
|
|
26
26
|
* @since 3.4.0
|
|
27
|
-
* @see
|
|
27
|
+
* @see {@link https://zh.wikipedia.org/wiki/统一资源定位符|统一资源定位符}
|
|
28
28
|
* @param {*} value 要检测的值
|
|
29
29
|
* @returns {boolean} 值是否为url
|
|
30
30
|
* @example
|
package/esm/isVehicle.js
CHANGED
|
@@ -8,8 +8,8 @@ var reg = /^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕
|
|
|
8
8
|
*
|
|
9
9
|
* @static
|
|
10
10
|
* @alias module:Validator.isVehicle
|
|
11
|
-
* @see 参考 {@link https://baike.baidu.com/item/车牌号|车牌号}
|
|
12
11
|
* @since 1.1.0
|
|
12
|
+
* @see {@link https://baike.baidu.com/item/车牌号|车牌号}
|
|
13
13
|
* @param {*} value 要检测的值
|
|
14
14
|
* @returns {boolean} 值是否为车牌号
|
|
15
15
|
* @example
|
package/esm/normalizeString.js
CHANGED
|
@@ -6,8 +6,8 @@ import convertToString from './utils/convertToString';
|
|
|
6
6
|
*
|
|
7
7
|
* @static
|
|
8
8
|
* @alias module:Processor.normalizeString
|
|
9
|
-
* @see 参考 {@link https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/String#string_instances|String}
|
|
10
9
|
* @since 4.3.0
|
|
10
|
+
* @see {@link https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/String#string_instances|String}
|
|
11
11
|
* @param {*} value 待处理的值
|
|
12
12
|
* @returns {string} 规整化的值
|
|
13
13
|
* @example
|
package/esm/parseIdCard.js
CHANGED
|
@@ -69,7 +69,7 @@ var Provinces = [
|
|
|
69
69
|
* @static
|
|
70
70
|
* @alias module:Processor.parseIdCard
|
|
71
71
|
* @since 4.0.0
|
|
72
|
-
* @see
|
|
72
|
+
* @see {@link https://baike.baidu.com/item/居民身份证号码|居民身份证号码}
|
|
73
73
|
* @param {string} id 身份证号码,支持15位
|
|
74
74
|
* @returns {IdCardInfo | null} 省份、生日、性别,省/市/区/年/月/日/性别编码。如果解析失败将返回 null 。
|
|
75
75
|
* @example
|
package/esm/safeDate.js
CHANGED
|
@@ -30,8 +30,8 @@ import _construct from "@babel/runtime/helpers/construct";
|
|
|
30
30
|
*
|
|
31
31
|
* @static
|
|
32
32
|
* @alias module:Processor.safeDate
|
|
33
|
-
* @see 参考 {@link https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Date|Date}
|
|
34
33
|
* @since 4.4.0
|
|
34
|
+
* @see {@link https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Date|Date}
|
|
35
35
|
* @param {string|number|Date} [value] 日期时间字符串、毫秒数、日期对象
|
|
36
36
|
* @param {...number} args 月/日/时/分/秒/毫秒
|
|
37
37
|
* @returns {Date} Date 实例日期对象
|
package/esm/setDataURLPrefix.js
CHANGED
|
@@ -4,9 +4,9 @@
|
|
|
4
4
|
*
|
|
5
5
|
* @static
|
|
6
6
|
* @alias module:Processor.setDataURLPrefix
|
|
7
|
-
* @see 参考 {@link https://developer.mozilla.org/zh-CN/docs/Web/HTTP/Basics_of_HTTP/Data_URIs|Data URLs}
|
|
8
|
-
* @see 参考 {@link https://mimesniff.spec.whatwg.org/#understanding-mime-types|MIME types}
|
|
9
7
|
* @since 4.1.0
|
|
8
|
+
* @see {@link https://developer.mozilla.org/zh-CN/docs/Web/HTTP/Basics_of_HTTP/Data_URIs|Data URLs}
|
|
9
|
+
* @see {@link https://mimesniff.spec.whatwg.org/#understanding-mime-types|MIME types}
|
|
10
10
|
* @param {string} data 数据本身
|
|
11
11
|
* @param {string} [mimetype="image/png"] MIME 类型
|
|
12
12
|
* @param {boolean} [base64=true] 添加 base64 标识
|
package/esm/utils/config.js
CHANGED
package/esm/validatePassword.js
CHANGED
|
@@ -129,10 +129,10 @@ function hasUnallowableCharacter(val, chars) {
|
|
|
129
129
|
/**
|
|
130
130
|
* 验证密码(数字、大小写字母、特殊字符、非法字符)
|
|
131
131
|
*
|
|
132
|
-
* @see 参考 {@link https://baike.baidu.com/item/ASCII#3|ASCII}
|
|
133
132
|
* @static
|
|
134
133
|
* @alias module:Validator.validatePassword
|
|
135
134
|
* @since 3.7.0
|
|
135
|
+
* @see {@link https://baike.baidu.com/item/ASCII#3|ASCII}
|
|
136
136
|
* @param {string} value 要检测的值
|
|
137
137
|
* @param {Object} [options] 配置项
|
|
138
138
|
* @param {number} [options.level=2] 密码强度 1-包含一种字符 2-包含两种字符 3-包含三种字符。(大写字母、小写字母、数字、特殊字符)
|
package/lib/blobToDataURL.js
CHANGED
|
@@ -15,11 +15,11 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "d
|
|
|
15
15
|
*
|
|
16
16
|
* <em style="font-weight: bold;">注意:该方法仅适用于浏览器端。</em>
|
|
17
17
|
*
|
|
18
|
+
* @ignore
|
|
18
19
|
* @static
|
|
19
20
|
* @alias module:Processor.blobToDataURL
|
|
20
|
-
* @see 参考 {@link https://developer.mozilla.org/zh-CN/docs/Web/API/FileReader/readAsDataURL|FileReader.readAsDataURL()}
|
|
21
21
|
* @since 4.1.0
|
|
22
|
-
* @
|
|
22
|
+
* @see {@link https://developer.mozilla.org/zh-CN/docs/Web/API/FileReader/readAsDataURL|FileReader.readAsDataURL()}
|
|
23
23
|
* @deprecated 请使用 `fileReader` 方法
|
|
24
24
|
* @param {Blob} blob Blob 或 File 对象
|
|
25
25
|
* @returns {Promise<string>} data:URL 格式的 Base64 字符串。
|
|
@@ -14,8 +14,8 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "d
|
|
|
14
14
|
* @static
|
|
15
15
|
* @alias module:Other.calculateCursorPosition
|
|
16
16
|
* @since 4.6.0
|
|
17
|
-
* @see
|
|
18
|
-
* @see
|
|
17
|
+
* @see {@link https://2950v9.csb.app/|h5示例}
|
|
18
|
+
* @see {@link https://33ccy9.csb.app/|react示例}
|
|
19
19
|
* @param {number} prevPos 赋值前的光标位置,onChange/onInput的光标位置 e.target.selectionEnd
|
|
20
20
|
* @param {string} prevCtrlValue 上一个格式化后的值
|
|
21
21
|
* @param {string} rawValue 当前输入原值
|
package/lib/dataURLToBlob.js
CHANGED
|
@@ -9,8 +9,8 @@ exports["default"] = void 0;
|
|
|
9
9
|
*
|
|
10
10
|
* @static
|
|
11
11
|
* @alias module:Processor.dataURLToBlob
|
|
12
|
-
* @see 参考 {@link https://developer.mozilla.org/zh-CN/docs/Glossary/Base64|Base64}
|
|
13
12
|
* @since 4.1.0
|
|
13
|
+
* @see {@link https://developer.mozilla.org/zh-CN/docs/Glossary/Base64|Base64}
|
|
14
14
|
* @param {string} dataurl data: 协议的URL
|
|
15
15
|
* @returns {Blob} Blob 对象
|
|
16
16
|
* @example
|
package/lib/download.js
CHANGED
|
@@ -8,6 +8,7 @@ var _dataURLToBlob = _interopRequireDefault(require("./dataURLToBlob"));
|
|
|
8
8
|
var _isUrl = _interopRequireDefault(require("./isUrl"));
|
|
9
9
|
var _ajax = _interopRequireDefault(require("./ajax"));
|
|
10
10
|
var _type = require("./utils/type");
|
|
11
|
+
var _isPromiseLike = _interopRequireDefault(require("./isPromiseLike"));
|
|
11
12
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
12
13
|
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
|
13
14
|
/**
|
|
@@ -45,13 +46,13 @@ function saver(blobUrl, fileName) {
|
|
|
45
46
|
/**
|
|
46
47
|
* @callback TransformRequest
|
|
47
48
|
* @param {AjaxOptions} options ajax 配置项
|
|
48
|
-
* @returns {AjaxOptions}
|
|
49
|
+
* @returns {AjaxOptions | Promise<AjaxOptions>}
|
|
49
50
|
*/
|
|
50
51
|
|
|
51
52
|
/**
|
|
52
53
|
* @callback TransformResponse
|
|
53
54
|
* @param {Blob} res 响应的Blob对象。如果你通过 transformRequest 修改了 responseType ,该参数将是该类型响应值。
|
|
54
|
-
* @returns {Blob}
|
|
55
|
+
* @returns {Blob | Promise<Blob>}
|
|
55
56
|
*/
|
|
56
57
|
|
|
57
58
|
/**
|
|
@@ -71,7 +72,8 @@ function saver(blobUrl, fileName) {
|
|
|
71
72
|
* @static
|
|
72
73
|
* @alias module:Other.download
|
|
73
74
|
* @since 4.16.0
|
|
74
|
-
* @see {@link https://zh.wikipedia.org/wiki
|
|
75
|
+
* @see {@link https://zh.wikipedia.org/wiki/多用途互聯網郵件擴展|MIME}
|
|
76
|
+
* @see {@link https://9ykc9s.csb.app/|在线示例}
|
|
75
77
|
* @param {string|Blob|ArrayBuffer|Int8Array|Uint8Array|Uint8ClampedArray|Int16Array|Uint16Array|Int32Array|Uint32Array|Float32Array|Float64Array|BigInt64Array|BigUint64Array} data 字符串、blob数据或url地址
|
|
76
78
|
* @param {string|DownloadOptions} [options] 文件名称 或 配置项
|
|
77
79
|
* @returns {Promise<void>}
|
|
@@ -111,21 +113,34 @@ function download(data, options) {
|
|
|
111
113
|
payload = (0, _dataURLToBlob["default"])(data);
|
|
112
114
|
} else if (dataType === 'url' || !dataType && (0, _isUrl["default"])(data)) {
|
|
113
115
|
// url
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
116
|
+
// 包装为异步方法
|
|
117
|
+
/** @type {(opts: AjaxOptions)=>Promise<AjaxOptions>} */
|
|
118
|
+
var asyncTransformRequest = function asyncTransformRequest(opts) {
|
|
119
|
+
// 请求前配置调整
|
|
120
|
+
var tempOptions = typeof transformRequest === 'function' ? transformRequest(opts) : opts;
|
|
121
|
+
// @ts-ignore
|
|
122
|
+
return (0, _isPromiseLike["default"])(tempOptions) ? tempOptions : Promise.resolve(tempOptions);
|
|
117
123
|
};
|
|
118
|
-
|
|
119
|
-
var
|
|
120
|
-
|
|
121
|
-
/** @type {Blob} */
|
|
124
|
+
/** @type {(res: Blob)=>Promise<Blob>} */
|
|
125
|
+
var asyncTransformResponse = function asyncTransformResponse(res) {
|
|
126
|
+
var tempRes = typeof transformResponse === 'function' ? transformResponse(res) : res;
|
|
122
127
|
// @ts-ignore
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
128
|
+
return (0, _isPromiseLike["default"])(tempRes) ? tempRes : Promise.resolve(tempRes);
|
|
129
|
+
};
|
|
130
|
+
|
|
131
|
+
// 此处如果使用 async/await 语法糖,编译后的umd代码过大
|
|
132
|
+
return asyncTransformRequest({
|
|
133
|
+
responseType: 'blob'
|
|
134
|
+
}).then(function (ajaxOptions) {
|
|
135
|
+
return (0, _ajax["default"])(data, ajaxOptions).then(function (e) {
|
|
136
|
+
// @ts-ignore
|
|
137
|
+
return asyncTransformResponse(e.target.response).then(function (res) {
|
|
138
|
+
var currentFileName = fileName || data.split("?")[0].split("#")[0].split("/").pop();
|
|
139
|
+
return download(res, {
|
|
140
|
+
fileName: currentFileName,
|
|
141
|
+
type: type || ((0, _type.isBlob)(res) ? res.type : undefined)
|
|
142
|
+
});
|
|
143
|
+
});
|
|
129
144
|
});
|
|
130
145
|
});
|
|
131
146
|
} else {
|
package/lib/fileReader.js
CHANGED
|
@@ -26,13 +26,13 @@ var FileReaderMethodMap = {
|
|
|
26
26
|
*/
|
|
27
27
|
|
|
28
28
|
/**
|
|
29
|
-
* 读取 Blob 或 File
|
|
29
|
+
* 读取 Blob 或 File 对象,可以将 Blob 转为 Base64/String/ArrayBuffer<br/><br/>
|
|
30
30
|
*
|
|
31
31
|
* <em style="font-weight: bold;">注意:该方法仅适用于浏览器端。</em>
|
|
32
32
|
*
|
|
33
33
|
* @static
|
|
34
34
|
* @alias module:Processor.fileReader
|
|
35
|
-
* @see
|
|
35
|
+
* @see {@link https://developer.mozilla.org/zh-CN/docs/Web/API/FileReader|FileReader}
|
|
36
36
|
* @since 4.16.0
|
|
37
37
|
* @param {Blob} blob Blob 或 File 对象
|
|
38
38
|
* @param {'arrayBuffer'|'binaryString'|'dataURL'|'text'} [type='dataURL'] Blob 或 File 对象
|
package/lib/interface.doc.js
CHANGED
|
@@ -82,13 +82,13 @@ function ajax(url, options) {}
|
|
|
82
82
|
/**
|
|
83
83
|
* @callback TransformRequest
|
|
84
84
|
* @param {AjaxOptions} options ajax 配置项
|
|
85
|
-
* @returns {AjaxOptions}
|
|
85
|
+
* @returns {AjaxOptions | Promise<AjaxOptions>}
|
|
86
86
|
*/
|
|
87
87
|
|
|
88
88
|
/**
|
|
89
89
|
* @callback TransformResponse
|
|
90
90
|
* @param {Blob} res 响应的Blob对象。如果你通过 transformRequest 修改了 responseType ,该参数将是该类型响应值。
|
|
91
|
-
* @returns {Blob}
|
|
91
|
+
* @returns {Blob | Promise<Blob>}
|
|
92
92
|
*/
|
|
93
93
|
|
|
94
94
|
/**
|
|
@@ -109,6 +109,7 @@ function ajax(url, options) {}
|
|
|
109
109
|
* @alias module:Other.download
|
|
110
110
|
* @since 4.16.0
|
|
111
111
|
* @see {@link https://zh.wikipedia.org/wiki/多用途互聯網郵件擴展|MIME}
|
|
112
|
+
* @see {@link https://9ykc9s.csb.app/|在线示例}
|
|
112
113
|
* @param {string|Blob|TypedArray} data 字符串、blob数据或url地址
|
|
113
114
|
* @param {string|DownloadOptions} [options] 文件名称 或 配置项
|
|
114
115
|
* @returns {Promise<void>}
|
package/lib/isBankCard.js
CHANGED
|
@@ -34,8 +34,8 @@ function sumCheckCode(numStr) {
|
|
|
34
34
|
*
|
|
35
35
|
* @static
|
|
36
36
|
* @alias module:Validator.isBankCard
|
|
37
|
-
* @see 参考 {@link https://kf.qq.com/faq/170112ABnm6b170112FvquAn.html|常用银行账号位数参考}
|
|
38
37
|
* @since 1.1.0
|
|
38
|
+
* @see {@link https://kf.qq.com/faq/170112ABnm6b170112FvquAn.html|常用银行账号位数参考}
|
|
39
39
|
* @param {*} value 要检测的值
|
|
40
40
|
* @param {Object} [options] 配置项
|
|
41
41
|
* @param {boolean} [options.loose=false] 宽松模式,8~30位数字
|
package/lib/isBusinessLicense.js
CHANGED
|
@@ -44,8 +44,8 @@ function sumCheckCode(preCode) {
|
|
|
44
44
|
*
|
|
45
45
|
* @static
|
|
46
46
|
* @alias module:Validator.isBusinessLicense
|
|
47
|
-
* @see 参考 {@link https://wenku.baidu.com/view/19873704cc1755270722087c.html|GS15—2006 工商行政管理市场主体注册号编制规则}
|
|
48
47
|
* @since 3.5.0
|
|
48
|
+
* @see {@link https://wenku.baidu.com/view/19873704cc1755270722087c.html|GS15—2006 工商行政管理市场主体注册号编制规则}
|
|
49
49
|
* @param {*} value 要检测的值
|
|
50
50
|
* @param {Object} [options] 配置项
|
|
51
51
|
* @param {boolean} [options.checkCode=true] 是否校验最后一位校验码,如果为false,不校验校验位。
|
package/lib/isChinese.js
CHANGED
|
@@ -39,9 +39,9 @@ var supportRegExpUnicode = RegExp.prototype.hasOwnProperty('unicode');
|
|
|
39
39
|
* @static
|
|
40
40
|
* @alias module:Validator.isChinese
|
|
41
41
|
* @since 1.1.0
|
|
42
|
-
* @see
|
|
43
|
-
* @see
|
|
44
|
-
* @see
|
|
42
|
+
* @see {@link http://www.unicode.org/reports/tr38/#BlockListing|4.4 Listing of Characters Covered by the Unihan Database}
|
|
43
|
+
* @see {@link https://zh.wikipedia.org/wiki/Unicode字符平面映射|Unicode字符平面映射}
|
|
44
|
+
* @see {@link https://zh.wikipedia.org/wiki/Unicode區段|Unicode区段}
|
|
45
45
|
* @param {*} value 要检测的值
|
|
46
46
|
* @param {Object} [options] 配置项
|
|
47
47
|
* @param {boolean} [options.loose=false] 宽松模式。如果为true,只要包含中文即为true
|
package/lib/isHMCard.js
CHANGED
|
@@ -15,7 +15,7 @@ var regHMCard = /^[hm]{1}([0-9]{10}|[0-9]{8})$/i;
|
|
|
15
15
|
* @static
|
|
16
16
|
* @alias module:Validator.isHMCard
|
|
17
17
|
* @since 4.0.0
|
|
18
|
-
* @see
|
|
18
|
+
* @see {@link https://zh.wikipedia.org/wiki/港澳居民来往内地通行证|港澳居民来往内地通行证}
|
|
19
19
|
* @param {*} value 要检测的值
|
|
20
20
|
* @returns {boolean} 是否为港澳居民来往内地通行证
|
|
21
21
|
* @example
|
package/lib/isIdCard.js
CHANGED
|
@@ -35,8 +35,8 @@ function check(id) {
|
|
|
35
35
|
* @static
|
|
36
36
|
* @alias module:Validator.isIdCard
|
|
37
37
|
* @since 1.1.0
|
|
38
|
-
* @see
|
|
39
|
-
* @see
|
|
38
|
+
* @see {@link https://zh.wikipedia.org/wiki/中华人民共和国公民身份号码|中华人民共和国公民身份号码}
|
|
39
|
+
* @see {@link https://baike.baidu.com/item/居民身份证号码|居民身份证号码}
|
|
40
40
|
* @param {*} value 要检测的值
|
|
41
41
|
* @param {Object} [options] 配置项
|
|
42
42
|
* @param {boolean} [options.loose=false] 宽松模式,支持15位身份证号码
|
package/lib/isPassport.js
CHANGED
|
@@ -15,8 +15,8 @@ var reg = /^((e[\da-z])|(de)|(se)|(pe)|([khm][\da-z]))[\da-z]{7}$/i;
|
|
|
15
15
|
*
|
|
16
16
|
* @static
|
|
17
17
|
* @alias module:Validator.isPassport
|
|
18
|
-
* @see 参考 {@link https://zh.wikipedia.org/wiki/中华人民共和国护照#个人资料页|中华人民共和国护照#个人资料页}
|
|
19
18
|
* @since 1.1.0
|
|
19
|
+
* @see {@link https://zh.wikipedia.org/wiki/中华人民共和国护照#个人资料页|中华人民共和国护照#个人资料页}
|
|
20
20
|
* @param {*} value 要检测的值
|
|
21
21
|
* @returns {boolean} 值是否为护照号
|
|
22
22
|
* @example
|
package/lib/isPassword.js
CHANGED
|
@@ -11,11 +11,11 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "d
|
|
|
11
11
|
* <p><strong>注意:该校验只校验是否存在不同字符(大小写字母、数字、特殊符号),不判断长度。</strong></p>
|
|
12
12
|
* <p><i>如果需要更细致的验证,请使用 <a href="#.validatePassword">validatePassword</a></i></p>
|
|
13
13
|
*
|
|
14
|
-
* @see 参考 {@link https://baike.baidu.com/item/ASCII#3|ASCII}
|
|
15
14
|
* @static
|
|
16
15
|
* @alias module:Validator.isPassword
|
|
17
|
-
* @since 1.1.0
|
|
18
16
|
* @requires module:Validator.validatePassword
|
|
17
|
+
* @since 1.1.0
|
|
18
|
+
* @see {@link https://baike.baidu.com/item/ASCII#3|ASCII}
|
|
19
19
|
* @param {*} value 要检测的值
|
|
20
20
|
* @param {Object} [options] 配置项
|
|
21
21
|
* @param {number} [options.level=2] 密码强度 1-包含一种字符 2-包含两种字符 3-包含三种字符。(大写字母、小写字母、数字、特殊字符)
|