使用docxtemplater-image-module-free时支持动态获取图片大小

使用docxtemplater-image-module-free时支持动态获取图片大小

1、问题背景

在使用docxtemplater-image-module-free生成模板图片时,写死了其中一个函数

javascript 复制代码
getSize() {
    return [150, 150];
},

导致图片都是一个大小,且被拉扯的变形了

2、报错信息

在去掉这个函数时报错:

shell 复制代码
Error: You should pass getSize

因此该函数必须规定图片的大小

3、电脑环境

  • 操作系统: Windows 11
  • docxtemplater-image-module-free:1.1.1
  • docxtemplater:3.40.3
  • node.js:18.18.2

4、解决问题

4.1、问题思路

查找docxtemplater-image-module-free的官方文档:https://docxtemplater.com/modules/image/#usage-browser

发现完全可以自定义图片的大小

4.2、解决方法

在浏览器环境中,使用Image对象动态获取图片的大小

js 复制代码
getSize(img, url, tagName) {
    return new Promise(function (resolve, reject) {
        const image = new Image();
        image.src = url;
        image.onload = function () {
            resolve([image.width, image.height]);
        };
        image.onerror = function (e) {
            console.log(
                "img, url, tagName : ",
                img,
                url,
                tagName
            );
            alert(
                "An error occured while loading " +
                    url
            );
            reject(e);
        };
    });
},

node.js环境中,使用image-size获取图片的大小

javascript 复制代码
const sizeOf = require("image-size");

getSize(img) {
    const sizeObj = sizeOf(img);
    return [sizeObj.width, sizeObj.height];
}

4.3、优化

一般原图都会比较大,甚至撑满整个docx文档,因此需要设置最大高度和宽度,来响应式计算宽高

javascript 复制代码
getSize(img) {
    const sizeObj = sizeOf(img);
    const maxWidth = 300
    const maxHeight = 300
    let width = Number(sizeObj.width) || 0
    let height = Number(sizeObj.height) || 0
    // 根据需要进行尺寸调整
    if (width > maxWidth) {
    	height *= maxWidth / width;
    	width = maxWidth;
    }
    if (height > maxHeight) {
    	width *= maxHeight / height;
    	height = maxHeight;
    }
    return [width, height];
}
相关推荐
因_崔斯汀3 小时前
Three.js 3D 地图特效与材质实现指南
前端
angerdream3 小时前
手把手编写儿童手机远程监控App之vue3用 AI Agent生成菜单
前端
cidy_983 小时前
Git Pull 代码冲突后完整回退教程
前端
JING小白3 小时前
Day 1 重学Vue:响应式系统的“底层逻辑”变更,Vue2旧时代的终结与Vue3新时代的开启
前端·vue.js
张就是我1065923 小时前
一个 ZIP 文件,把 webshell 写到了不该在的地方
前端
张就是我1065923 小时前
SPIP 的一个漏洞:你以为过滤了,其实没过滤干净
前端
一tiao咸鱼4 小时前
我用 Claude 做了一个 AI 面试刷题系统,支持 DeepSeek / 阿里 / GPT 帮你打分
前端
掘金一周4 小时前
对车完全小白,不知买油买电还是买混动,求建议| 沸点周刊 7.2
前端·人工智能·后端
妙码生花5 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十六):目录结构更新、完善 token 系统(AI 表示 token 入库无需加密?)
前端·后端·ai编程
程序me5 小时前
Prompt、Context、Harness、Loop 之后是什么? AI工程下一个半年的关键词
前端·后端·ai编程