辅助工具 
| 函数名 | 描述 | 类型 | 参数 | 返回值 | 
|---|---|---|---|---|
| isClient | 是否浏览器环境 | boolean | - | Boolean | 
| fileToBase64 | 文件对象 File 转换为 base64 | (file:File) => base64 | (file:文件对象) | Base64 | 
| formDataToJson | FormData 转换为json | (data:FormData) => Json | (data:表单数据) | Json | 
| dataURLtoBlob | Base64 转换 Blob | (dataUrl:string) => Blob | (dataUrl:Base64) | Blob | 
| blobToFile | Blob 转 File | (blob:Blob,fileName:string) => File | (blob:Blob,fileName:文件名称) | File | 
示例 
在控制台查看效果
<template>
  <div>
    <XAction label="isClient" type="primary" @click="onClick"></XAction>
    <XAction
      label="fileToBase64"
      type="primary"
      @click="onClickFileToBase64"></XAction>
    <XAction
      label="formDataToJson"
      type="success"
      @click="onClickFormDataToJson"></XAction>
    <XAction
      label="dataURLtoBlob"
      type="warning"
      @click="onClickDataURLtoBlob"></XAction>
    <XAction
      label="blobToFile"
      type="danger"
      @click="onClickBlobToFile"></XAction>
  </div>
</template>
<script setup lang="ts">
  import { XAction } from '@vtj/ui';
  import {
    isClient,
    fileToBase64,
    formDataToJson,
    dataURLtoBlob,
    blobToFile
  } from '@vtj/utils';
  const onClick = () => {
    console.log('isClient', isClient);
  };
  const onClickFileToBase64 = async () => {
    const file = new File(['foo'], 'foo.txt', {
      type: 'text/plain'
    });
    const FileToBase64 = await fileToBase64(file);
    console.log('FileToBase64', FileToBase64);
    // FileToBase64 data:text/plain;base64,Zm9v
  };
  const onClickFormDataToJson = async () => {
    const formData = new FormData(); // 当前为空
    formData.append('username', 'admin');
    const FormDataToJson = formDataToJson(formData);
    console.log('FormDataToJson', FormDataToJson);
    // FormDataToJson {username: 'admin'}
  };
  const onClickDataURLtoBlob = () => {
    const imgUrl =
      '';
    const DataURLtoBlob = dataURLtoBlob(imgUrl);
    console.log('DataURLtoBlob', DataURLtoBlob);
    // DataURLtoBlob Blob {size: 45, type: 'image/gif'}
  };
  const onClickBlobToFile = () => {
    const blobParts = ['<q id="a"><span id="b">hey!</span></q>']; // 一个包含单个字符串的数组
    const blob = new Blob(blobParts, { type: 'text/html' }); // 得到 blob
    const BlobToFile = blobToFile(blob, 'vtj.text');
    console.log('BlobToFile', BlobToFile);
    // DataURLtoBlob => Blob对象
  };
</script>
<style scoped></style>isClient 
是否浏览器环境
js
  import {isClient} from '@vtj/utils';
  const onClick = () => {
    console.log('isClient', isClient);
    // isClient true or false
  };fileToBase64 
文件对象 File 转换为 base64
js
  import { fileToBase64 } from '@vtj/utils';  
  const onClickFileToBase64 = async () => {
    const file = new File(['foo'], 'foo.txt', {
      type: 'text/plain'
    });
    const FileToBase64 = await fileToBase64(file);
    console.log('FileToBase64', FileToBase64);
    // FileToBase64 data:text/plain;base64,Zm9v
  };formDataToJson 
FormData 转换为json
js
  import { formDataToJson } from '@vtj/utils';  
  const onClickFormDataToJson = async () => {
    const formData = new FormData(); // 当前为空
    formData.append('username', 'admin');
    const FormDataToJson = formDataToJson(formData);
    console.log('FormDataToJson', FormDataToJson);
    // FormDataToJson {username: 'admin'}
  };dataURLtoBlob 
Base64 转换 Blob
js
  import { dataURLtoBlob } from '@vtj/utils';  
  const onClickDataURLtoBlob = () => {
    const imgUrl =
      '';
    const DataURLtoBlob = dataURLtoBlob(imgUrl);
    console.log('DataURLtoBlob', DataURLtoBlob);
    // DataURLtoBlob Blob {size: 45, type: 'image/gif'}
  };blobToFile 
Blob 转 File
js
  import { blobToFile } from '@vtj/utils';  
  const onClickBlobToFile = () => {
    const blobParts = ['<q id="a"><span id="b">hey!</span></q>']; // 一个包含单个字符串的数组
    const blob = new Blob(blobParts, { type: 'text/html' }); // 得到 blob
    const BlobToFile = blobToFile(blob, 'vtj.html');
    console.log('BlobToFile', BlobToFile);
    // DataURLtoBlob => Blob对象
  };