@bettergi/utils 0.1.6 → 0.1.7
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/README.md +3 -0
- package/dist/misc.d.ts +6 -0
- package/dist/misc.js +15 -0
- package/dist/store.d.ts +6 -0
- package/dist/store.js +11 -0
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -183,4 +183,7 @@ const uuid = generateUUID(false);
|
|
|
183
183
|
// 数组洗牌
|
|
184
184
|
const arr = [1, 2, 3, 4, 5];
|
|
185
185
|
const shuffled = shuffleArray(arr);
|
|
186
|
+
|
|
187
|
+
// 深度合并多个对象:{ x: 1, y: { a: 2, b: 4, c: 5 }, d: 6 }
|
|
188
|
+
const result = deepMerge({ x: 1, y: { a: 2, b: 3 } }, { y: { b: 4, c: 5 }, d: 6 });
|
|
186
189
|
```
|
package/dist/misc.d.ts
CHANGED
|
@@ -9,3 +9,9 @@ export declare const generateUUID: (withDashes?: boolean) => string;
|
|
|
9
9
|
* @returns 洗牌后的新数组
|
|
10
10
|
*/
|
|
11
11
|
export declare const shuffleArray: <T>(array: T[]) => T[];
|
|
12
|
+
/**
|
|
13
|
+
* 深度合并多个对象
|
|
14
|
+
* @param objects 多个对象
|
|
15
|
+
* @returns 合并后的对象副本
|
|
16
|
+
*/
|
|
17
|
+
export declare const deepMerge: (...objects: any[]) => any;
|
package/dist/misc.js
CHANGED
|
@@ -24,3 +24,18 @@ export const shuffleArray = (array) => {
|
|
|
24
24
|
}
|
|
25
25
|
return shuffled;
|
|
26
26
|
};
|
|
27
|
+
/**
|
|
28
|
+
* 深度合并多个对象
|
|
29
|
+
* @param objects 多个对象
|
|
30
|
+
* @returns 合并后的对象副本
|
|
31
|
+
*/
|
|
32
|
+
export const deepMerge = (...objects) => {
|
|
33
|
+
const isPlainObject = (input) => input?.constructor === Object;
|
|
34
|
+
return objects.reduce((result, obj) => {
|
|
35
|
+
return Object.entries(obj).reduce((acc, [key, value]) => {
|
|
36
|
+
const recursive = isPlainObject(acc[key]) && isPlainObject(value);
|
|
37
|
+
acc[key] = recursive ? deepMerge(acc[key], value) : value;
|
|
38
|
+
return acc;
|
|
39
|
+
}, result);
|
|
40
|
+
}, {});
|
|
41
|
+
};
|
package/dist/store.d.ts
CHANGED
|
@@ -5,3 +5,9 @@
|
|
|
5
5
|
* @param name 存储对象的名称,将作为文件名(不包扩展名)
|
|
6
6
|
*/
|
|
7
7
|
export declare const useStore: <T extends Record<string, any>>(name: string) => T;
|
|
8
|
+
/**
|
|
9
|
+
* 创建一个带有默认值的持久化存储对象,用于管理应用状态数据
|
|
10
|
+
* @param name 存储对象的名称,将作为文件名(不包扩展名)
|
|
11
|
+
* @param defaults 默认值数据对象
|
|
12
|
+
*/
|
|
13
|
+
export declare const useStoreWithDefaults: <T extends Record<string, any>>(name: string, defaults: Partial<T>) => T;
|
package/dist/store.js
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { deepMerge } from "./misc";
|
|
1
2
|
/**
|
|
2
3
|
* 创建一个持久化存储对象,用于管理应用状态数据
|
|
3
4
|
* 该函数会创建一个代理对象,对该对象的所有属性的修改都会自动同步到相应的JSON文件(脚本的 `store` 目录下)中。
|
|
@@ -50,3 +51,13 @@ export const useStore = (name) => {
|
|
|
50
51
|
};
|
|
51
52
|
return createProxy(obj);
|
|
52
53
|
};
|
|
54
|
+
/**
|
|
55
|
+
* 创建一个带有默认值的持久化存储对象,用于管理应用状态数据
|
|
56
|
+
* @param name 存储对象的名称,将作为文件名(不包扩展名)
|
|
57
|
+
* @param defaults 默认值数据对象
|
|
58
|
+
*/
|
|
59
|
+
export const useStoreWithDefaults = (name, defaults) => {
|
|
60
|
+
const store = useStore(name);
|
|
61
|
+
Object.assign(store, deepMerge(defaults, store));
|
|
62
|
+
return store;
|
|
63
|
+
};
|