@ivujs/i-utils 1.1.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.
Files changed (132) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +149 -0
  3. package/dist/cjs/ID-card/index.cjs +122 -0
  4. package/dist/cjs/array/index.cjs +465 -0
  5. package/dist/cjs/clipboard/index.cjs +135 -0
  6. package/dist/cjs/color/index.cjs +210 -0
  7. package/dist/cjs/constants/date.cjs +186 -0
  8. package/dist/cjs/constants/lang.cjs +13 -0
  9. package/dist/cjs/constants/math.cjs +13 -0
  10. package/dist/cjs/constants/regexp.cjs +57 -0
  11. package/dist/cjs/constants/sort.cjs +15 -0
  12. package/dist/cjs/cookie/index.cjs +71 -0
  13. package/dist/cjs/crypto/aes/aes.cjs +533 -0
  14. package/dist/cjs/crypto/aes/index.cjs +28 -0
  15. package/dist/cjs/crypto/base32/base32.cjs +385 -0
  16. package/dist/cjs/crypto/base32/index.cjs +44 -0
  17. package/dist/cjs/crypto/base64/base64.cjs +433 -0
  18. package/dist/cjs/crypto/base64/index.cjs +64 -0
  19. package/dist/cjs/crypto/des/des.cjs +1054 -0
  20. package/dist/cjs/crypto/des/index.cjs +30 -0
  21. package/dist/cjs/crypto/md5/index.cjs +25 -0
  22. package/dist/cjs/crypto/md5/md5.cjs +944 -0
  23. package/dist/cjs/crypto/sha/sha1/index.cjs +25 -0
  24. package/dist/cjs/crypto/sha/sha1/sha1.cjs +602 -0
  25. package/dist/cjs/crypto/sha/sha256/index.cjs +46 -0
  26. package/dist/cjs/crypto/sha/sha256/sha256.cjs +654 -0
  27. package/dist/cjs/crypto/sha/sha3/index.cjs +44 -0
  28. package/dist/cjs/crypto/sha/sha3/sha3.cjs +747 -0
  29. package/dist/cjs/crypto/sha/sha512/index.cjs +88 -0
  30. package/dist/cjs/crypto/sha/sha512/sha512.cjs +1186 -0
  31. package/dist/cjs/crypto/sm/lib/asn1.cjs +167 -0
  32. package/dist/cjs/crypto/sm/lib/ec.cjs +352 -0
  33. package/dist/cjs/crypto/sm/lib/jsbn.cjs +1633 -0
  34. package/dist/cjs/crypto/sm/lib/sm3.cjs +173 -0
  35. package/dist/cjs/crypto/sm/lib/utils.cjs +198 -0
  36. package/dist/cjs/crypto/sm/sm2/index.cjs +122 -0
  37. package/dist/cjs/crypto/sm/sm2/sm2.cjs +269 -0
  38. package/dist/cjs/crypto/sm/sm3/index.cjs +15 -0
  39. package/dist/cjs/crypto/sm/sm3/sm3.cjs +103 -0
  40. package/dist/cjs/crypto/sm/sm4/index.cjs +28 -0
  41. package/dist/cjs/crypto/sm/sm4/sm4.cjs +362 -0
  42. package/dist/cjs/crypto/tea/index.cjs +26 -0
  43. package/dist/cjs/crypto/tea/tea.cjs +215 -0
  44. package/dist/cjs/date/index.cjs +1349 -0
  45. package/dist/cjs/desensitized/index.cjs +74 -0
  46. package/dist/cjs/device/index.cjs +159 -0
  47. package/dist/cjs/dom/index.cjs +176 -0
  48. package/dist/cjs/file/index.cjs +339 -0
  49. package/dist/cjs/function/index.cjs +67 -0
  50. package/dist/cjs/id/index.cjs +46 -0
  51. package/dist/cjs/index.cjs +399 -0
  52. package/dist/cjs/keycode/index.cjs +142 -0
  53. package/dist/cjs/math/index.cjs +284 -0
  54. package/dist/cjs/number/index.cjs +14 -0
  55. package/dist/cjs/object/index.cjs +216 -0
  56. package/dist/cjs/pagination/index.cjs +140 -0
  57. package/dist/cjs/random/index.cjs +25 -0
  58. package/dist/cjs/regexp/index.cjs +109 -0
  59. package/dist/cjs/storage/index.cjs +11 -0
  60. package/dist/cjs/storage/localStorage.cjs +40 -0
  61. package/dist/cjs/storage/sessionStorage.cjs +40 -0
  62. package/dist/cjs/string/index.cjs +338 -0
  63. package/dist/cjs/url/index.cjs +279 -0
  64. package/dist/cjs/validate/index.cjs +487 -0
  65. package/dist/cjs/weapp/index.cjs +151 -0
  66. package/dist/es/ID-card/index.mjs +116 -0
  67. package/dist/es/array/index.mjs +437 -0
  68. package/dist/es/clipboard/index.mjs +129 -0
  69. package/dist/es/color/index.mjs +200 -0
  70. package/dist/es/constants/date.mjs +184 -0
  71. package/dist/es/constants/lang.mjs +11 -0
  72. package/dist/es/constants/math.mjs +11 -0
  73. package/dist/es/constants/regexp.mjs +55 -0
  74. package/dist/es/constants/sort.mjs +13 -0
  75. package/dist/es/cookie/index.mjs +65 -0
  76. package/dist/es/crypto/aes/aes.mjs +529 -0
  77. package/dist/es/crypto/aes/index.mjs +25 -0
  78. package/dist/es/crypto/base32/base32.mjs +381 -0
  79. package/dist/es/crypto/base32/index.mjs +39 -0
  80. package/dist/es/crypto/base64/base64.mjs +427 -0
  81. package/dist/es/crypto/base64/index.mjs +57 -0
  82. package/dist/es/crypto/des/des.mjs +1050 -0
  83. package/dist/es/crypto/des/index.mjs +27 -0
  84. package/dist/es/crypto/md5/index.mjs +22 -0
  85. package/dist/es/crypto/md5/md5.mjs +941 -0
  86. package/dist/es/crypto/sha/sha1/index.mjs +22 -0
  87. package/dist/es/crypto/sha/sha1/sha1.mjs +599 -0
  88. package/dist/es/crypto/sha/sha256/index.mjs +41 -0
  89. package/dist/es/crypto/sha/sha256/sha256.mjs +649 -0
  90. package/dist/es/crypto/sha/sha3/index.mjs +39 -0
  91. package/dist/es/crypto/sha/sha3/sha3.mjs +742 -0
  92. package/dist/es/crypto/sha/sha512/index.mjs +79 -0
  93. package/dist/es/crypto/sha/sha512/sha512.mjs +1177 -0
  94. package/dist/es/crypto/sm/lib/asn1.mjs +164 -0
  95. package/dist/es/crypto/sm/lib/ec.mjs +349 -0
  96. package/dist/es/crypto/sm/lib/jsbn.mjs +1630 -0
  97. package/dist/es/crypto/sm/lib/sm3.mjs +170 -0
  98. package/dist/es/crypto/sm/lib/utils.mjs +186 -0
  99. package/dist/es/crypto/sm/sm2/index.mjs +111 -0
  100. package/dist/es/crypto/sm/sm2/sm2.mjs +258 -0
  101. package/dist/es/crypto/sm/sm3/index.mjs +13 -0
  102. package/dist/es/crypto/sm/sm3/sm3.mjs +99 -0
  103. package/dist/es/crypto/sm/sm4/index.mjs +25 -0
  104. package/dist/es/crypto/sm/sm4/sm4.mjs +359 -0
  105. package/dist/es/crypto/tea/index.mjs +23 -0
  106. package/dist/es/crypto/tea/tea.mjs +211 -0
  107. package/dist/es/date/index.mjs +1262 -0
  108. package/dist/es/desensitized/index.mjs +69 -0
  109. package/dist/es/device/index.mjs +145 -0
  110. package/dist/es/dom/index.mjs +164 -0
  111. package/dist/es/file/index.mjs +323 -0
  112. package/dist/es/function/index.mjs +63 -0
  113. package/dist/es/id/index.mjs +43 -0
  114. package/dist/es/index.mjs +59 -0
  115. package/dist/es/keycode/index.mjs +139 -0
  116. package/dist/es/math/index.mjs +274 -0
  117. package/dist/es/number/index.mjs +12 -0
  118. package/dist/es/object/index.mjs +203 -0
  119. package/dist/es/pagination/index.mjs +134 -0
  120. package/dist/es/random/index.mjs +22 -0
  121. package/dist/es/regexp/index.mjs +98 -0
  122. package/dist/es/storage/index.mjs +9 -0
  123. package/dist/es/storage/localStorage.mjs +35 -0
  124. package/dist/es/storage/sessionStorage.mjs +35 -0
  125. package/dist/es/string/index.mjs +321 -0
  126. package/dist/es/url/index.mjs +261 -0
  127. package/dist/es/validate/index.mjs +451 -0
  128. package/dist/es/weapp/index.mjs +140 -0
  129. package/dist/lib/index.full.esm.js +15825 -0
  130. package/dist/lib/index.full.esm.min.js +58 -0
  131. package/dist/lib/index.full.umd.js +16179 -0
  132. package/package.json +54 -0
@@ -0,0 +1,321 @@
1
+ /**
2
+ * 去除字符串前后位置空格
3
+ * @param {String} value 参数
4
+ * @returns {String} 返回处理后的字符串
5
+ */
6
+ function trim(value) {
7
+ return value.replace(/(^\s*)|(\s*$)/g, "");
8
+ }
9
+
10
+ /**
11
+ * 去除字符串开始位置的空格
12
+ * @param {String} value 参数
13
+ * @returns {String} 返回处理后的字符串
14
+ */
15
+ function trimStart(value) {
16
+ return value.replace(/(^\s*)/g, "");
17
+ }
18
+
19
+ /**
20
+ * 去除字符串结束位置的空格
21
+ * @param {String} value 参数
22
+ * @returns {String} 返回处理后的字符串
23
+ */
24
+ function trimEnd(value) {
25
+ return value.replace(/(\s*$)/g, "");
26
+ }
27
+
28
+ /**
29
+ * 去除字符串中全部的空格
30
+ * @param {String} value 参数
31
+ * @returns {String} 返回处理后的字符串
32
+ */
33
+ function trimAll(value) {
34
+ return value.replace(/\s+/g, "");
35
+ }
36
+
37
+ /**
38
+ * 替换所有指定字符串为新的字符串
39
+ * @param {String} value 参数
40
+ * @param {String} oldSubstr 需要替换的字符串
41
+ * @param {String} newSubstr 替换后的字符串
42
+ * @returns {String} 返回处理后的字符串
43
+ */
44
+ function replaceAll(value, oldSubstr, newSubstr) {
45
+ return value.replace(new RegExp(oldSubstr, "gm"), newSubstr);
46
+ }
47
+
48
+ /* 字符串转换 */
49
+ /**
50
+ * 字符串转大写
51
+ * @param {String} value 参数
52
+ * @returns {String} 返回处理后的字符串
53
+ */
54
+ function toUpper(value) {
55
+ return String(value).toLocaleUpperCase();
56
+ }
57
+
58
+ /**
59
+ * 字符串转小写
60
+ * @param {String} value 参数
61
+ * @returns {String} 返回处理后的字符串
62
+ */
63
+ function toLower(value) {
64
+ String(value).toLocaleLowerCase();
65
+ }
66
+
67
+ /**
68
+ * 转为 snake_case 下划线命名
69
+ * @description 支持 驼峰命名,短横命名,帕斯卡命名
70
+ * @param {String} value 参数
71
+ * @returns {String} 返回处理后的字符串
72
+ */
73
+ function toSnakeCase(value) {
74
+ // 驼峰
75
+ if (/^[a-z]$/.test(value.charAt(0)) && !(value.indexOf("-") > 0 || value.indexOf("_") > 0)) {
76
+ return value.replace(/([A-Z])/g, "_$1").toLowerCase();
77
+ }
78
+ // 短横
79
+ if (value.indexOf("-") > 0) {
80
+ return value.replace(/-/g, "_").toLowerCase();
81
+ }
82
+ // 帕斯卡
83
+ if (/^[A-Z]$/.test(value.charAt(0)) && !(value.indexOf("-") > 0 || value.indexOf("_") > 0)) {
84
+ value = value.charAt(0).toLowerCase() + value.slice(1);
85
+ return value.replace(/([A-Z])/g, "_$1").toLowerCase();
86
+ }
87
+ }
88
+
89
+ /**
90
+ * 转为 kebab-case 短横命名
91
+ * @description 支持 下划线,驼峰命名,帕斯卡命名
92
+ * @param {String} value 参数
93
+ * @returns {String} 返回处理后的字符串
94
+ */
95
+ function toKebabCase(value) {
96
+ // 下划线
97
+ if (value.indexOf("_") > 0) {
98
+ return value.replace(/_/g, "-").toLowerCase();
99
+ }
100
+ // 驼峰
101
+ if (/^[a-z]$/.test(value.charAt(0)) && !(value.indexOf("-") > 0 || value.indexOf("_") > 0)) {
102
+ return value.replace(/([A-Z])/g, "-$1").toLowerCase();
103
+ }
104
+ // 帕斯卡
105
+ if (/^[A-Z]$/.test(value.charAt(0)) && !(value.indexOf("-") > 0 || value.indexOf("_") > 0)) {
106
+ let newStr = value.charAt(0).toLowerCase() + value.slice(1);
107
+ return newStr.replace(/([A-Z])/g, "-$1").toLowerCase();
108
+ }
109
+ }
110
+
111
+ /**
112
+ * 转为 camelCase 驼峰命名
113
+ * @description 支持 下划线命名,短横命名,帕斯卡命名
114
+ * @param {String} value 参数
115
+ * @returns {String} 返回处理后的字符串
116
+ */
117
+ function toCamelCase(value) {
118
+ // 下划线
119
+ if (value.indexOf("_") > 0) {
120
+ return value.replace(/\_(\w)/g, function (all, letter) {
121
+ return letter.toUpperCase();
122
+ });
123
+ }
124
+ // 短横
125
+ else if (value.indexOf("-") > 0) {
126
+ return value.replace(/\-(\w)/g, function (all, letter) {
127
+ return letter.toUpperCase();
128
+ });
129
+ }
130
+ // 帕斯卡
131
+ else if (/^[A-Z]$/.test(value.charAt(0)) && !(value.indexOf("-") > 0 || value.indexOf("_") > 0)) {
132
+ return value.charAt(0).toLowerCase() + value.slice(1);
133
+ }
134
+ // 返回自身
135
+ else {
136
+ return value;
137
+ }
138
+ }
139
+
140
+ /**
141
+ * 转为 PascalCase 帕斯卡命名
142
+ * @description 支持 下划线命名,短横命名,驼峰命名
143
+ * @param {String} value 参数
144
+ * @returns {String} 返回处理后的字符串
145
+ */
146
+ function toPascalCase(value) {
147
+ // 下划线
148
+ if (value.indexOf("_") > 0) {
149
+ let newStr = value.replace(/\_(\w)/g, function (all, letter) {
150
+ return letter.toUpperCase();
151
+ });
152
+ return newStr.charAt(0).toUpperCase() + newStr.slice(1);
153
+ }
154
+ // 短横
155
+ else if (value.indexOf("-") > 0) {
156
+ let newStr = value.replace(/\-(\w)/g, function (all, letter) {
157
+ return letter.toUpperCase();
158
+ });
159
+ return newStr.charAt(0).toUpperCase() + newStr.slice(1);
160
+ }
161
+ // 驼峰
162
+ else if (/^[a-z]$/.test(value.charAt(0)) && !(value.indexOf("-") > 0 || value.indexOf("_") > 0)) {
163
+ return value.charAt(0).toUpperCase() + value.slice(1);
164
+ }
165
+ // 返回自身
166
+ else {
167
+ return value;
168
+ }
169
+ }
170
+
171
+ /* 字符串格式化 */
172
+ /**
173
+ * 字符串中是否包含指定的元素
174
+ * @param {String} value 包含的元素
175
+ * @param {String} str 查找的字符串
176
+ * @returns {Boolean} 返回true和false
177
+ */
178
+ function inString(value, str) {
179
+ return str.includes(value);
180
+ }
181
+
182
+ /**
183
+ * 数字前补齐0达到指定位数
184
+ * @description 相当于原生的 padStart(2,'0')
185
+ * @param {Number|String} value 补零的数字
186
+ * @param {Number} maxLength 补齐0后的最大长度,默认2位
187
+ * @returns {String} 返回补0后指定位数的字符串
188
+ */
189
+ function zeroStart(value, maxLength = 2) {
190
+ let len = value.toString().length;
191
+ while (len < maxLength) {
192
+ value = "0" + value;
193
+ len++;
194
+ }
195
+ return value;
196
+ }
197
+
198
+ /**
199
+ * 数字后补齐0达到指定位数
200
+ * @description 相当于原生的 padEnd(2,'0')
201
+ * @param {Number|String} value 补零的数字
202
+ * @param {Number} maxLength 补齐0后的最大长度,默认2位
203
+ * @returns {String} 返回补0后指定位数的字符串
204
+ */
205
+ function zeroEnd(value, maxLength = 2) {
206
+ let len = value.toString().length;
207
+ while (len < maxLength) {
208
+ value = value + "0";
209
+ len++;
210
+ }
211
+ return value;
212
+ }
213
+
214
+ /**
215
+ * 格式化千分位数字
216
+ * @description 支持任意数据传参,如果非数字则不会格式化,并返回原数据
217
+ * @param {Number|String} num 数字
218
+ * @returns {String} 返回格式化后的千分位数字
219
+ */
220
+ function formatThousand(num) {
221
+ if (!parseFloat(num)) return num;
222
+ num = String(num);
223
+ let regex = num.indexOf(".") > -1 ? /(\d)(?=(\d{3})+\.)/g : /(\d)(?=(?:\d{3})+$)/g;
224
+ return num.replace(regex, "$1,");
225
+ }
226
+
227
+ /**
228
+ * 格式化人民币金额大写
229
+ * @param {Number|String} money 金额
230
+ * @returns {String} 返回金额大写
231
+ */
232
+ function formatRmbChinese(money) {
233
+ // 汉字的数字
234
+ let cnNums = ["零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖"];
235
+ // 基本单位
236
+ let cnIntRadiance = ["", "拾", "佰", "仟"];
237
+ // 对应整数部分扩展单位
238
+ let cnIntUnits = ["", "万", "亿", "兆"];
239
+ // 对应小数部分单位
240
+ let cnDecUnits = ["角", "分", "毫", "厘"];
241
+ // 整数金额时后面跟的字符
242
+ let cnInteger = "整";
243
+ // 整型完以后的单位
244
+ let cnIntLast = "元";
245
+ // 最大处理的数字
246
+ let maxNum = Number("999999999999999.9999");
247
+ // 金额整数部分
248
+ let integerNum;
249
+ // 金额小数部分
250
+ let decimalNum;
251
+ // 输出的中文金额字符串
252
+ let chineseStr = "";
253
+ // 分离金额后用的数组,预定义
254
+ let parts;
255
+ if (money === "") {
256
+ // 不能用==
257
+ return "";
258
+ }
259
+ money = parseFloat(money);
260
+ if (money >= maxNum) {
261
+ // 超出最大处理数字,抛出异常
262
+ throw new Error("Calculated number overflow!");
263
+ }
264
+ if (money === 0) {
265
+ chineseStr = cnNums[0] + cnIntLast + cnInteger;
266
+ return chineseStr;
267
+ }
268
+ // 转换为字符串
269
+ money = money.toString();
270
+ if (money.indexOf(".") === -1) {
271
+ integerNum = money;
272
+ decimalNum = "";
273
+ } else {
274
+ parts = money.split(".");
275
+ integerNum = parts[0];
276
+ decimalNum = parts[1].substr(0, 4);
277
+ }
278
+ // 获取整型部分转换
279
+ if (parseInt(integerNum, 10) > 0) {
280
+ let zeroCount = 0;
281
+ let IntLen = integerNum.length;
282
+ for (let i = 0; i < IntLen; i++) {
283
+ let n = integerNum.substr(i, 1);
284
+ let p = IntLen - i - 1;
285
+ let q = p / 4;
286
+ let m = p % 4;
287
+ if (n === "0") {
288
+ zeroCount++;
289
+ } else {
290
+ if (zeroCount > 0) {
291
+ chineseStr += cnNums[0];
292
+ }
293
+ // 归零
294
+ zeroCount = 0;
295
+ chineseStr += cnNums[parseInt(n)] + cnIntRadiance[m];
296
+ }
297
+ if (m === 0 && zeroCount < 4) {
298
+ chineseStr += cnIntUnits[q];
299
+ }
300
+ }
301
+ chineseStr += cnIntLast;
302
+ }
303
+ // 小数部分
304
+ if (decimalNum !== "") {
305
+ let decLen = decimalNum.length;
306
+ for (let i = 0; i < decLen; i++) {
307
+ let n = decimalNum.substr(i, 1);
308
+ if (n !== "0") {
309
+ chineseStr += cnNums[Number(n)] + cnDecUnits[i];
310
+ }
311
+ }
312
+ }
313
+ if (chineseStr === "") {
314
+ chineseStr += cnNums[0] + cnIntLast + cnInteger;
315
+ } else if (decimalNum === "") {
316
+ chineseStr += cnInteger;
317
+ }
318
+ return chineseStr;
319
+ }
320
+
321
+ export { formatRmbChinese, formatThousand, inString, replaceAll, toCamelCase, toKebabCase, toLower, toPascalCase, toSnakeCase, toUpper, trim, trimAll, trimEnd, trimStart, zeroEnd, zeroStart };
@@ -0,0 +1,261 @@
1
+ import { REGEXP } from '../constants/regexp.mjs';
2
+ import { isArray } from '../validate/index.mjs';
3
+ import { arrayInsertBefore, arrayInsertAfter } from '../array/index.mjs';
4
+
5
+ /**
6
+ * 获得协议名
7
+ * @param {String} url url地址,默认当前url地址
8
+ * @returns {String} 返回协议名
9
+ */
10
+ function getProtocol(url = window.location.href) {
11
+ let match = url.match(REGEXP.URL);
12
+ if (match) {
13
+ return match[1] || "";
14
+ }
15
+ }
16
+
17
+ /**
18
+ * 获得主机地址
19
+ * @param {String} url url地址,默认当前url地址
20
+ * @returns {String} 返回主机地址
21
+ */
22
+ function getHost(url = window.location.href) {
23
+ let match = url.match(REGEXP.URL);
24
+ if (match) {
25
+ return (match[2] || "") + (match[3] ? ":" + match[3] : "");
26
+ }
27
+ }
28
+
29
+ /**
30
+ * 获得主机名称
31
+ * @param {String} url url地址,默认当前url地址
32
+ * @returns {String} 返回主机名称
33
+ */
34
+ function getHostName(url = window.location.href) {
35
+ let match = url.match(REGEXP.URL);
36
+ if (match) {
37
+ return match[2] || "";
38
+ }
39
+ }
40
+
41
+ /**
42
+ * 获得端口号
43
+ * @param {String} url url地址,默认当前url地址
44
+ * @returns {String} 返回端口号
45
+ */
46
+ function getPort(url = window.location.href) {
47
+ let match = url.match(REGEXP.URL);
48
+ if (match) {
49
+ return match[3] || "";
50
+ }
51
+ }
52
+
53
+ /**
54
+ * 获得地址路径
55
+ * @param {String} url url地址,默认当前url地址
56
+ * @returns {String} 返回地址路径
57
+ */
58
+ function getUrlPath(url = window.location.href) {
59
+ let match = url.match(REGEXP.URL);
60
+ if (match) {
61
+ return match[4] || "";
62
+ }
63
+ }
64
+
65
+ /**
66
+ * 获得hash字符串
67
+ * @param {String} url url地址,默认当前url地址
68
+ * @returns {String} 返回hash字符串
69
+ */
70
+ function getUrlHash(url = window.location.href) {
71
+ let match = url.match(REGEXP.URL);
72
+ if (match) {
73
+ return match[6] || "";
74
+ }
75
+ }
76
+
77
+ /**
78
+ * 获得查询参数字符串
79
+ * @param {String} url url地址,默认当前url地址
80
+ * @returns {String} 返回查询参数字符串
81
+ */
82
+ function getSearchString(url = window.location.href) {
83
+ let match = url.match(REGEXP.URL);
84
+ console.log(match);
85
+ if (match) {
86
+ return match[5] || "";
87
+ }
88
+ }
89
+
90
+ /**
91
+ * 查询参数字符串中获得某个参数的值
92
+ * @param {String} name 参数名
93
+ * @param {String} url url地址,默认当前url地址
94
+ * @returns {String} 返回查询到的值
95
+ */
96
+ function getSearchParam(name, url = window.location.href) {
97
+ name = name.replace(/[[\]]/g, "\\$&");
98
+ url = getSearchString(url);
99
+ let reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)");
100
+ let match = url.substring(0).match(reg);
101
+ if (match) {
102
+ return decodeURIComponent(match[2]);
103
+ }
104
+ }
105
+
106
+ /**
107
+ * 查询参数字符串中设置某个参数的值
108
+ * @param {String} name 参数名
109
+ * @param {String,Number,Array} value 参数值,如果是数组,则解析为:&ids[0]=1&ids[2]=2
110
+ * @param {String} url url地址,默认当前url地址
111
+ * @returns {String} 返回查询参数字符串
112
+ */
113
+ function setSearchParam(name, value, url = window.location.href) {
114
+ let params = toSearchParam(url);
115
+ params[name] = value;
116
+
117
+ // 返回替换后的url
118
+ return url.replace(/(\?.+?)(?=#|$)/, "?" + toSearchString(params));
119
+ }
120
+
121
+ /**
122
+ * 查询参数字符串中是否包含某个参数
123
+ * @param {String} name 参数名
124
+ * @param {String} url url地址,默认当前url地址
125
+ * @returns {Boolean} 返回结果
126
+ */
127
+ function hasSearchParam(name, url = window.location.href) {
128
+ let params = toSearchParam(url);
129
+ return params[name] !== undefined;
130
+ }
131
+
132
+ /**
133
+ * 查询参数字符串中在最前面追加新参数和值
134
+ * @param {String} name 参数名
135
+ * @param {String,Number,Array} value 参数值,如果是数组,则解析为:&ids[0]=1&ids[2]=2
136
+ * @param {String} url url地址,默认当前url地址
137
+ * @returns {String} 返回查询参数字符串
138
+ */
139
+ function prependSearchParam(name, value, url = window.location.href) {
140
+ let searchArr = getSearchString(url).split("&");
141
+ if (isArray(value)) {
142
+ let arr = [];
143
+ for (let i = 0; i < value.length; i++) {
144
+ arr.push(`${encodeURIComponent(name)}[${i}]=${encodeURIComponent(value[i])}`);
145
+ }
146
+ searchArr.unshift(...arr);
147
+ } else {
148
+ searchArr.unshift(`${encodeURIComponent(name)}=${encodeURIComponent(value)}`);
149
+ }
150
+
151
+ return url.replace(/(\?.+?)(?=#|$)/, "?" + searchArr.join("&"));
152
+ }
153
+
154
+ /**
155
+ * 查询参数字符串中在某个参数的前面追加新参数和值
156
+ * @param {String} name 参数名
157
+ * @param {String,Number,Array} value 参数值,如果是数组,则解析为:&ids[0]=1&ids[2]=2
158
+ * @param {String} beforeParam 在前面追加参数的名称
159
+ * @param {String} url url地址,默认当前url地址
160
+ * @returns {String} 返回查询参数字符串
161
+ */
162
+ function prependToSearchParam(name, value, beforeParam, url = window.location.href) {
163
+ let searchArr = getSearchString(url).split("&");
164
+ let beforeIndex = searchArr.findIndex((v) => v.includes(beforeParam));
165
+ let beforeArr = arrayInsertBefore(searchArr, beforeIndex, `${name}=${value}`);
166
+
167
+ return url.replace(/(\?.+?)(?=#|$)/, "?" + beforeArr.join("&"));
168
+ }
169
+
170
+ /**
171
+ * 查询参数字符串中在最后面追加新参数和值
172
+ * @param {String} name 参数名
173
+ * @param {String,Number,Array} value 参数值,如果是数组,则解析为:&ids[0]=1&ids[2]=2
174
+ * @param {String} url url地址,默认当前url地址
175
+ * @returns {String} 返回查询参数字符串
176
+ */
177
+ function appendSearchParam(name, value, url = window.location.href) {
178
+ let searchArr = getSearchString(url).split("&");
179
+ searchArr.push(`${name}=${value}`);
180
+
181
+ return url.replace(/(\?.+?)(?=#|$)/, "?" + searchArr.join("&"));
182
+ }
183
+
184
+ /**
185
+ * 查询参数字符串中在某个参数的后面追加新参数和值
186
+ * @param {String} name 参数名
187
+ * @param {String,Number,Array} value 参数值,如果是数组,则解析为:&ids[0]=1&ids[2]=2
188
+ * @param {String} afterName 在后面追加参数的名称
189
+ * @param {String} url url地址,默认当前url地址
190
+ * @returns {String} 返回查询参数字符串
191
+ */
192
+ function appendToSearchParam(name, value, afterName, url = window.location.href) {
193
+ let searchArr = getSearchString(url).split("&");
194
+ let beforeIndex = searchArr.findIndex((v) => v.includes(afterName));
195
+ let afterArr = arrayInsertAfter(searchArr, beforeIndex, `${name}=${value}`);
196
+
197
+ return url.replace(/(\?.+?)(?=#|$)/, "?" + afterArr.join("&"));
198
+ }
199
+
200
+ /**
201
+ * 查询参数字符串中移除某个参数和值
202
+ * @param {String} name 参数名
203
+ * @param {String} url url地址,默认当前url地址
204
+ * @returns {String} 返回查询参数字符串
205
+ */
206
+ function removeSearchParam(name, url = window.location.href) {
207
+ let searchArr = getSearchString(url).split("&");
208
+ let delIndex = searchArr.findIndex((v) => v.includes(name));
209
+ if (delIndex > -1) {
210
+ searchArr.splice(delIndex, 1);
211
+ }
212
+
213
+ return url.replace(/(\?.+?)(?=#|$)/, "?" + searchArr.join("&"));
214
+ }
215
+
216
+ /**
217
+ * 查询参数字符串转为对象
218
+ * @param {String} url url地址,默认当前url地址
219
+ * @returns {Object} 返回参数对象
220
+ */
221
+ function parseSearchParam(url = window.location.href) {
222
+ let searchString = getSearchString(url);
223
+ let searchArr = searchString.split("&");
224
+ let param = {};
225
+ for (let i = 0; i < searchArr.length; i++) {
226
+ let arr = searchArr[i].split("=");
227
+ param[decodeURIComponent(arr[0])] = decodeURIComponent(arr[1] || "");
228
+ }
229
+ return param;
230
+ }
231
+
232
+ /**
233
+ * 对象转为查询参数字符串
234
+ * @param {Object} params 参数对象
235
+ * @param {String} url url地址,如果不为空,则会拼接好查询参数字符串的url地址
236
+ * @returns {String} 返回查询参数字符串
237
+ */
238
+ function formatSearchString(params, url = undefined) {
239
+ if (typeof params !== "object") return params;
240
+
241
+ let arr = [];
242
+ for (let key in params) {
243
+ let value = params[key];
244
+ if (isArray(value)) {
245
+ for (let i = 0; i < value.length; ++i) {
246
+ arr.push(encodeURIComponent(key + "[" + i + "]") + "=" + encodeURIComponent(value[i]));
247
+ }
248
+ } else {
249
+ arr.push(encodeURIComponent(key) + "=" + encodeURIComponent(params[key]));
250
+ }
251
+ }
252
+
253
+ // 如果url不为空,则会返回拼接好url字符串
254
+ if (url) {
255
+ return url.replace(/(\?.+?)(?=#|$)/, "?" + arr.join("&"));
256
+ } else {
257
+ return arr.join("&");
258
+ }
259
+ }
260
+
261
+ export { appendSearchParam, appendToSearchParam, formatSearchString, getHost, getHostName, getPort, getProtocol, getSearchParam, getSearchString, getUrlHash, getUrlPath, hasSearchParam, parseSearchParam, prependSearchParam, prependToSearchParam, removeSearchParam, setSearchParam };