@mt-kit/utils
Version:
518 lines (376 loc) • 10.8 kB
Markdown
# @mt-kit/utils
## 下载
```bash
npm i @mt-kit/utils
```
## 使用
[See](https://github.com/Not-have/micro-tools/tree/main/packages-utils/stories)
## API
### animationFrameThrottle
- 使用 requestAnimationFrame 创建函数节流版本,限制函数在特定时间内的调用次数
| 参数名 | 说明 | 是否必穿 |
| ----------- | ------------------------- | ----------|
| fn | 回调函数 | 是 |
```ts
// 滚动事件处理
window.addEventListener('scroll', animationFrameThrottle(handleScroll));
// 窗口大小改变
window.addEventListener('resize', animationFrameThrottle(handleResize));
// 动画效果
const animatedFunction = animationFrameThrottle(updateAnimation);
```
### imageBase64ToBlob
- 将 Base64 格式的图片转换为 Blob 对象
| 参数名 | 说明 | 是否必穿 |
| ----------- | ----------- | ----------- |
| base64 | 图片base64 | 是 |
```ts
const base64Data = '...';
const blob = imageBase64ToBlob(base64Data);
```
### imageUrlToBase64
- 将图片 URL 转换为 Base64 格式
| 参数名 | 说明 | 是否必穿 | 默认值 |
| ----------- | ----------- | ----------- | ----------- |
| url | 图片url | 是 | - |
| mineType | 用于指定生成的 base64 字符串的 MIME 类型 | 否 | image/png |
```ts
imageUrlToBase64('https://example.com/image.png')
.then(base64 => {
console.log(base64); // data:image/png;base64,...
});
```
### downloadByUrl
- 根据文件地址进行下载
| 参数名 | 说明 | 是否必穿 |
| ----------- | ----------- | ----------- |
| url | 图片url | 是 |
| target | 链接的打开方式,默认为 '_blank' | 否 |
| fileName | 文件名 | 否 |
```ts
downloadByUrl({
url: 'https://example.com/document.pdf',
target: '_blank',
fileName: 'my-document.pdf'
});
```
### downloadDataFile
- 根据文件数据进行下载
| 参数名 | 说明 | 是否必穿 |
| -------- | ------- | ----------|
| data | Blob 对象的 BlobPart 参数 | 是 |
| filename | 保存的文件名 |是 |
| mime | 文件的 MIME 类型 | 否 |
| blob | Blob 对象的 BlobPart 参数 | 否 |
```ts
const data = new Uint8Array([72, 101, 108, 108, 111]); // "Hello" 的 ASCII 码
downloadDataFile(data, 'hello.txt', 'text/plain');
```
### downloadBase64File
- 根据 Base64 数据下载文件
| 参数名 | 说明 | 是否必穿 |
| -------- | ------- | ----------|
| base64 | base64字符串 | 是 |
| filename | 保存的文件名 |是 |
| blob | 文件的 MIME 类型 | 否 |
```ts
const base64Data = 'data:text/plain;base64,SGVsbG8gV29ybGQh'; // "Hello World!"
downloadBase64File(base64Data, 'hello.txt');
```
### downloadUrlFile
- 根据在线图片的 URL 进行下载
| 参数名 | 说明 | 是否必穿 |
| -------- | ------- | ----------|
| url | 图片url | 是 |
| filename | 保存的文件名 |是 |
| mime | 文件的 MIME 类型 | 否 |
| blob | Blob 对象的 BlobPart 参数 | 否 |
```ts
downloadUrlFile(
'https://example.com/image.png',
'my-image.png',
'image/png'
);
```
### copyText
- 复制文本到剪贴板
| 参数名 | 说明 | 是否必穿 |
| -------- | ------- | ----------|
| text | 要复制的文本 | 是 |
| fn | 复制成功的回调 | 否 |
```ts
copyText('Hello World!').then(() => {
console.log('文本已复制到剪贴板');
});
```
### queryStringToObject
- 将查询字符串转换为对象
| 参数名 | 说明 | 是否必穿 |
| -------- | ------- | ----------|
| queryString | 查询字符串 | 是 |
```ts
const query = queryStringToObject('?name=John&age=30');
console.log(query); // { name: 'John', age: '30' }
```
### openWindow
- 打开新窗口
| 参数名 | 说明 | 是否必穿 |
| -------- | ------- | ----------|
| url | 链接地址 | 是 |
| options | 链接的打开方式,默认为 '_blank' | 否 |
```ts
openWindow('https://example.com', {
target: '_blank',
features: 'width=800,height=600'
});
```
### cookieHelper
- Cookie 操作助手
| 参数名 | 说明 | 是否必穿 |
| -------- | ------- | ----------|
| name | cookie名称 | 是 |
| value | cookie值 | 是 |
| options | cookie的配置选项 | 否 |
方法:
- get(name) : 获取指定名称的 cookie
- set(name, value, options) : 设置 cookie
- remove(name) : 删除指定名称的 cookie
```ts
// 设置 cookie
cookieHelper.set('username', 'John', { expires: 7 }); // 7天过期
// 获取 cookie
const username = cookieHelper.get('username');
// 删除 cookie
cookieHelper.remove('username');
```
### localStorageHelper
- localStorage 操作助手
| 参数名 | 说明 | 是否必穿 |
| -------- | ------- | ----------|
| name | 本地存储名称 | 是 |
| value | 本地存储值 | 是 |
方法:
- get(name) : 获取指定名称的本地存储
- set(name, value) : 设置本地存储
- remove(name) : 删除指定名称的本地存储
- clear() : 清空所有数据
```ts
// 设置数据
localStorageHelper.set('user', { name: 'John', age: 30 });
// 获取数据
const user = localStorageHelper.get('user');
// 删除数据
localStorageHelper.remove('user');
// 清空所有数据
localStorageHelper.clear();
```
### isElement
- 判断是否为 DOM 元素
| 参数名 | 说明 | 是否必穿 |
| -------- | ------- | ----------|
| element | 元素 | 是 |
```ts
const div = document.createElement('div');
console.log(isElement(div)); // true
console.log(isElement({})); // false
```
### isFunction
- 判断是否为函数
| 参数名 | 说明 | 是否必穿 |
| -------- | ------- | ----------|
| fn | 函数 | 是 |
```ts
console.log(isFunction(() => {})); // true
console.log(isFunction({})); // false
```
### isEqual
- 比较两个对象是否相等
| 参数名 | 说明 | 是否必穿 |
| -------- | ------- | ----------|
| a | 比较值 | 是 |
| b | 比较值 | 是 |
```ts
const objA = { a: 1, b: { c: 2 } };
const objB = { a: 1, b: { c: 2 } };
const objC = { a: 1, b: { c: 3 } };
console.log(isEqual(objA, objB)); // true
console.log(isEqual(objA, objC)); // false
```
### isNull
- 判断是否为 null
| 参数名 | 说明 | 是否必穿 |
| -------- | ------- | ----------|
| value | 值 | 是 |
```ts
console.log(isNull(null)); // true
console.log(isNull(undefined)); // false
console.log(isNull(0)); // false
```
### isObject
- 判断是否为对象类型
| 参数名 | 说明 | 是否必穿 |
| -------- | ------- | ----------|
| value | 值 | 是 |
```ts
console.log(isObject({})); // true
console.log(isObject([])); // true
console.log(isObject(null)); // false
console.log(isObject('string')); // false
```
### isUndefined
- 判断是否为 undefined
| 参数名 | 说明 | 是否必穿 |
| -------- | ------- | ----------|
| value | 值 | 是 |
```ts
console.log(isUndefined(undefined)); // true
console.log(isUndefined(null)); // false
console.log(isUndefined(0)); // false
```
### clone
- 浅拷贝对象
| 参数名 | 说明 | 是否必穿 |
| -------- | ------- | ----------|
| value | 值 | 是 |
```ts
const obj = { a: 1, b: { c: 2 } };
const cloned = clone(obj);
console.log(cloned); // { a: 1, b: { c: 2 } }
console.log(cloned.b === obj.b); // true,浅拷贝,引用相同
```
### cloneDeep
- 深拷贝对象
| 参数名 | 说明 | 是否必穿 |
| -------- | ------- | ----------|
| value | 值 | 是 |
```ts
const obj = { a: 1, b: { c: 2 } };
const cloned = cloneDeep(obj);
console.log(cloned); // { a: 1, b: { c: 2 } }
console.log(cloned.b === obj.b); // false,深拷贝,引用不同
```
### debounce
- 创建一个防抖函数,延迟调用函数直到上一次调用后的一段时间已经过去
| 参数名 | 说明 | 是否必穿 |
| -------- | ------- | ----------|
| fn | 要防抖的函数 | 是 |
| wait | 延迟时间(毫秒) | 是 |
| options | 配置选项 | 否 |
```ts
// 搜索输入防抖
const debouncedSearch = debounce((query) => {
fetchSearchResults(query);
}, 300);
// 在输入框中使用
inputElement.addEventListener('input', (e) => {
debouncedSearch(e.target.value);
});
```
### throttle
- 创建一个节流函数,限制函数在一段时间内只能调用一次
| 参数名 | 说明 | 是否必穿 |
| -------- | ------- | ----------|
| fn | 要节流的函数 | 是 |
| wait | 节流时间(毫秒) | 是 |
| options | 配置选项 | 否 |
```ts
// 滚动事件节流
const throttledScroll = throttle(() => {
updateScrollPosition();
}, 100);
// 在滚动事件中使用
window.addEventListener('scroll', throttledScroll);
```
### omitBy
- 创建一个从对象中排除满足条件的属性的新对象
| 参数名 | 说明 | 是否必穿 |
| -------- | ------- | ----------|
| obj | 源对象 | 是 |
| condition | 用于判断是否排除属性的条件函数 | 是 |
```ts
const sampleObject = {
a: 1,
b: 2,
c: 3,
d: 4,
};
// 从对象中排除值大于 2 的属性
const result = omitBy(sampleObject, (value) => value > 2);
console.log(result); // { a: 1, b: 2 }
```
### objectValueToString
- 将对象的值转换为字符串
| 参数名 | 说明 | 是否必穿 |
| -------- | ------- | ----------|
| obj | 源对象 | 是 |
```ts
const obj = {
id: 123,
active: true,
score: 98.5
};
const stringified = objectValueToString(obj);
console.log(stringified);
// 输出: { id: '123', active: 'true', score: '98.5' }
```
### IframeMessage
- 创建一个 iframe 便签,与内嵌的页面进行通讯
调用界面
```tsx
import {
JSX,
useCallback,
useMemo
} from "react";
import {
IframeMessage
} from "@mt-kit/utils";
export default function DemoIframeMessage(): JSX.Element {
const url = "http://localhost:5173/";
const iframe = useMemo(() => {
const communicator = new IframeMessage();
communicator.createIframe(url);
return communicator;
}, [url]);
const handleClick = useCallback(() => {
iframe.postMessage({
type: "message",
data: {
name: "hello",
age: 18
}
});
}, [iframe]);
return <div>
<p>iframe 通信</p>
<button onClick={handleClick}>传值</button>
</div>;
}
```
接收通信
```vue
<script setup lang="ts">
import {
onMounted,
onUnmounted
} from "vue";
import {
Message,
IframeMessage
} from "@mt-kit/utils";
const iframe = new IframeMessage();
const handleMessage = (e: Message ): void => {
console.log(e);
};
onMounted(() => {
iframe.onMessage(handleMessage);
});
onUnmounted(() => {
iframe.removeMessageListener(handleMessage);
});
</script>
<template>
</template>
<style scoped>
</style>
```