HTML中dom转成图片进行存储

简介: 做作业的时候,需要在手机上预览下,但是发现如果想在移动端上展示A4样子的作业还是挺麻烦的,最后还是准备通过图片来展示,然后移动端缩放呗。。
最近在做试卷相关的业务,碰到一个场景,需要将试卷在移动端进行卷面还原,考虑到在WEB端实现的A4的样式在移动端上不好实现且比较难看,最终选择通过图片进行预览,这样在移动端也可以进行缩放查看。

业务流程

  • 创建试卷卷面
  • 将卷面保存为图片
  • 在移动端直接展示图片

流程比较简单,下面主要说下关于图片生成以及保存这部分的实现。

使用插件

html2canvas
canvas转图片
图片上传保存

html2canvas

该插件可以实现,将某些HTML中的dom转化成canvas进行展现,使用非常简单,而且还原度相当高。
插件地址:http://html2canvas.hertzen.com/

使用起来超级简单:

html2canvas(document.querySelector("#capture")).then(canvas => {
    document.body.appendChild(canvas)
});

将canvas生成图片

代码如下:

let dataurl = canvas.toDataURL('image/png');

上面是将canvas转成base64的字符串,下面将字符串转成form表单中的File对象,然后通过异步将文件保存。

let dataurl = canvas.toDataURL('image/png');
let arr = dataurl.split(',');
let mime = arr[0].match(/:(.*?);/)[1];
let suffix = mime.split('/')[1];
let bstr = atob(arr[1]);
let n = bstr.length;
let u8arr = new Uint8Array(n);
while (n--) {
  u8arr[n] = bstr.charCodeAt(n)
}
//生成File对象
let file = new File([u8arr], `preview.${suffix}`, {type: mime});
let fd = new FormData();
fd.append("file",file);
fd.append("module","preview");
$.ajax({
    type : 'post',
    url : base+'/file/upload',
    data : fd,
    processData: false,
    contentType:false,
    success : function(res){
        if(res.success){
            resolve(res);
        }else{
            reject(res.msg);
        }
    },
    error : function(e){
        reject("图片信息保存失败,请刷新后重试!");
    }
});

关于后台接受

至于下面后端接收图片并处理的这里简单放下代码就不说明了,我这是传到了FTP服务器上保存的,后端是基于spring-boot框架实现的。

/**
 * 单文件上传
 *
 * @param file
 * @param request
 * @return
 */
@PostMapping("/upload")
@ResponseBody
public Map upload(@RequestParam("file") MultipartFile file, HttpServletRequest request) {
    //返回MAP 给前台数据使用
    String module = request.getParameter("module");
    Map map = new HashMap();
    if (!file.isEmpty()) {
        try {
            String fileName = file.getOriginalFilename();
            Attachment attach = new Attachment();
            attach.setId(new Uuid().getUUID());
            attach.setSystem("smartteaching");
            attach.setFileName(fileName);
            attach.setModule(module);
            attach.setSuffix(FileUtil.getFileExt(fileName));
            FtpStorageHandlerImpl fshl = new FtpStorageHandlerImpl();
            fshl.upload(file.getInputStream(), attach);
            map.put("filePath", attach.getFilePath());
            map.put("fileSize", file.getSize());
            map.put("fileName", attach.getFileName());
            map.put("suffix", attach.getSuffix());
            map.put("success", true);
        } catch (IOException e) {
            e.printStackTrace();
            map.put("success", false);
            map.put("msg", "上传失败");
        }

        return map;
    } else {
        map.put("success", false);
        map.put("msg", "文件不存在或为空");
        return map;
    }
}

结束

到了这一步,完整的从前端将DOM生成图片,并将图片上传至后端就完成了。

相关文章
|
2月前
|
存储 Web App开发 移动开发
HTML5 Web 存储详解
HTML5 Web存储提供了两种客户端数据存储机制:**Local Storage**和**Session Storage**。Local Storage用于长期存储数据,即使关闭浏览器数据也依然存在,适用于保存用户偏好设置等信息。Session Storage则在标签或窗口关闭时清除数据,适合存储临时信息。两者均提供了简单的API进行数据的存取操作,但需要注意的是,Web存储并非加密存储,不应存放敏感信息。现代浏览器普遍支持Web存储,合理利用这两种存储方式可提升Web应用的用户体验。
|
3月前
|
JavaScript 前端开发 容器
用HTML DOM实现有条件地渲染网页元素(上)
用HTML DOM实现有条件地渲染网页元素(上)
|
3月前
|
存储 JavaScript 前端开发
用HTML DOM实现有条件地渲染网页元素(下)
用HTML DOM实现有条件地渲染网页元素(下)
|
1月前
利用html2canvas插件自定义生成名片信息并保存图片
这是一个利用html2canvas插件自定义生成名片信息并保存图片,自定义上传头像,自定义输入个人信息内容,自定义图片名称,并将生成的图片保存到本地
38 1
利用html2canvas插件自定义生成名片信息并保存图片
|
2月前
|
JavaScript
HTML DOM 节点树
HTML DOM 节点是指在 HTML 文档对象模型中,文档中的所有内容都被视为节点。整个文档是一个文档节点,每个 HTML 元素是元素节点,元素内的文本是文本节点,属性是属性节点,注释是注释节点。DOM 将文档表示为节点树,节点之间有父子和同胞关系。
|
2月前
|
JavaScript
HTML DOM 节点
HTML DOM(文档对象模型)将HTML文档视为节点树,其中每个部分都是节点:文档本身是文档节点,HTML元素是元素节点,元素内的文本是文本节点,属性是属性节点,注释是注释节点。节点间存在父子及同胞关系,形成层次结构。
|
3月前
|
JavaScript 前端开发
JavaScript HTML DOM
JavaScript HTML DOM
43 2
JavaScript HTML DOM
|
2月前
HTML图片
【10月更文挑战第4天】HTML图片。
35 2
|
2月前
|
JavaScript 前端开发 编译器
吐血整理:纯前端如何实现批量dom转图片,并下载成压缩包
【10月更文挑战第2天】吐血整理:纯前端如何实现批量dom转图片,并下载成压缩包
61 2
|
2月前
|
存储 移动开发 缓存
HTML5 Web 存储详解
HTML5 Web 存储包括 `localStorage` 和 `sessionStorage`,前者提供持久存储且无过期时间,后者仅在会话期间有效。两者均支持键值对形式存储数据,容量约为 5-10 MB。`localStorage` 适用于用户偏好设置、登录状态保持及离线应用缓存;`sessionStorage` 则用于临时数据如表单输入。数据以字符串形式存储,可通过 `JSON` 方法处理对象。由于数据存储于本地,不适合存放敏感信息。示例代码展示了如何使用按钮将输入框内容保存至 `localStorage` 并进行清除操作。