页面上的内容的生成图片后,保存为word,并下载

页面上的内容的生成图片后,保存为word,并下载 juqery

复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Download Page Screenshot as Word</title>
    <script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/FileSaver.js/2.0.5/FileSaver.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/html2canvas/1.3.2/html2canvas.min.js"></script>
</head>
<body>
    <div id="content-to-capture">
        <!-- This is the content you want to capture -->
        <h1>Hello, World!</h1>
        <p>This is an example paragraph.</p>
    </div>
    <button id="downloadWord">Download Word</button>
    <script>
        $(document).ready(function() {
            $('#downloadWord').click(function() {
                html2canvas(document.getElementById('content-to-capture')).then(function(canvas) {
                    // Convert canvas to data URL
                    const dataUrl = canvas.toDataURL('image/png');

                    // Create a Blob from the data URL
                    const byteString = atob(dataUrl.split(',')[1]);
                    const mimeString = dataUrl.split(',')[0].split(':')[1].split(';')[0];
                    const ab = new ArrayBuffer(byteString.length);
                    const ia = new Uint8Array(ab);
                    for (let i = 0; i < byteString.length; i++) {
                        ia[i] = byteString.charCodeAt(i);
                    }
                    const blob = new Blob([ab], {type: mimeString});

                    // Generate a simple .doc file content
                    const content = `
                        <html xmlns:o='urn:schemas-microsoft-com:office:office' 
                              xmlns:w='urn:schemas-microsoft-com:office:word' 
                              xmlns='http://www.w3.org/TR/REC-html40'>
                        <head><meta charset='utf-8'><title>Export HTML to Word Document with JavaScript</title></head>
                        <body>
                            <img src='${dataUrl}' />
                        </body>
                        </html>
                    `;

                    // Create a Blob for the .doc file
                    const docBlob = new Blob(['\ufeff', content], {type: 'application/msword'});

                    // Save the Blob as a file
                    saveAs(docBlob, 'document.doc');
                });
            });
        });
    </script>
</body>
</html>
相关推荐
拉不动的猪1 天前
浏览器之内置四大多线程API
前端·javascript·浏览器
林太白1 天前
5大排序算法&2大搜索&4大算法思想
前端
摇滚侠1 天前
浏览器的打印功能,如果通过HTML5,控制样式
前端·html·html5
喵喵侠w1 天前
uni-app微信小程序相机组件二次拍照白屏问题的排查与解决
前端·数码相机·微信小程序·小程序·uni-app
超大只番薯1 天前
在Next.js中实现页面级别KeepAlive
前端
快递鸟1 天前
第三方物流接口优选:快递鸟物流 API,打破单一快递对接壁垒
前端
黑咩狗夜.cm1 天前
Aspose.word实现表格每页固定表头、最后一行填满整个页面
开发语言·c#·word
Mapmost1 天前
【高斯泼溅】从一张好照片开始:Mapmost 3DGS建模之图像采集指南
前端
gCode Teacher 格码致知1 天前
Python教学基础:用Python和openpyxl结合Word模板域写入数据-由Deepseek产生
python·word
李少兄1 天前
解决 Chrome 下载 `.crx` 文件被自动删除及“无法安装扩展程序,因为它使用了不受支持的清单版本”问题
前端·chrome