uniapp实现html转换为图片并下载

在使用uniapp开发支付宝小程序时,碰到了需要将html转化为图片并下载的需求,发现在支付宝小程序中无法使用html2canvas进行处理,所以使用canvas自己绘制的方式,主要代码如下所示:

html 复制代码
<view id="container">
<!-- 需要转换的html代码 -->
</view>
<canvas id="myCanvas"></canvas>
javascript 复制代码
my.createSelectorQuery().select('#container').boundingClientRect().exec((ret) => {
    const rect = ret[0];
    //rect为container实例对象,可以获取到宽高等参数
    const context = my.createCanvasContext('myCanvas');
    //手写需要绘制的内容
    context.fillText('申请人姓名:小如', 10, 10)
    context.draw(true, () => {
        my.canvasToTempFilePath({
            canvasId: 'myCanvas',
            success: (res) => {
                console.log('图片路径:' + res.tempFilePath);
                my.saveImageToPhotosAlbum({
                    filePath: res.tempFilePath,
                    success(res) {
                        console.log(res);
                    },
                    fail(err) {
                        console.log(err);
                    },
                });
            },
            fail: (err) => {
                console.error('生成图片失败:', err);
            }
        });
    });
})

在h5页面中,可以使用html2canvas进行处理

javascript 复制代码
import html2canvas from 'html2canvas';
import { saveAs } from 'file-saver';

//调用save方法进行转换
save() {
  const container = document.querySelector('#container'); // 获取包含需要保存为图片的元素的容器
  // 使用html2canvas将元素转换为canvas
  html2canvas(container).then((canvas) => {
    let url = canvas.toDataURL('image/png');
    this.src = url;  //获取到了url可以直接在界面中展示
    // 将canvas转换为Blob对象
    // canvas.toBlob((blob) => {
    //   saveAs(blob, '考试安排.png');
    //   uni.saveImageToPhotosAlbum({
    //     filePath: blob,
    //     success() {
    //       uni.showToast({
    //         title: '保存成功',
    //         icon: 'success'
    //       });
    //     },
    //     fail() {
    //       uni.showToast({
    //         title: '保存失败',
    //         icon: 'none'
    //       });
    //     }
    //   });
    // }, 'image/png');
  });
}
相关推荐
excel2 分钟前
如何将 MP4 文件转换为 M3U8 格式并实现流媒体播放
前端
秋氘渔7 分钟前
Vue基础语法及项目相关指令详解
前端·javascript·vue.js
IT_陈寒9 分钟前
React性能优化实战:我用这5个技巧将组件渲染速度提升了70%
前端·人工智能·后端
2501_9151063212 分钟前
iOS 抓包全流程指南,HTTPS 抓包、TCP 数据流分析与多工具协同的方法论
android·tcp/ip·ios·小程序·https·uni-app·iphone
邱泽贤16 分钟前
uniapp 当前页调用上一页的方法
前端·javascript·uni-app
不一样的少年_16 分钟前
大部分人都错了!这才是chrome插件多脚本通信的正确姿势
前端·javascript·浏览器
集成显卡21 分钟前
AI取名大师 | uni-app 微信小程序打包 v-bind、component 动态组件问题
人工智能·微信小程序·uni-app
Moment22 分钟前
Angular v21 无 Zone 模式前瞻:新特性、性能提升与迁移方案
前端·javascript·angular.js
yqcoder26 分钟前
vue2 和 vue3 中,provide 和 inject 用法
前端·javascript·vue.js
艾小码26 分钟前
Vue组件开发避坑指南:循环引用、更新控制与模板替代
前端·javascript·vue.js