Vue网页中使用PDF.js弹窗显示pdf文档所有内容

本文中使用的PDF.js组件版本为3.11.174(最新版使用上会有所不同),引入文件如下:

首先页面定义一个隐藏的弹窗块(此处用ElementUI的Dialog组件)

html 复制代码
<el-dialog ref="dialogPDF" :title="pdffile.name" center :visible.sync="isPDFVisible" width="80%"  :close-on-click-modal="true"  :show-close="true">
    <div>
        @*<canvas id="pdf-canvas"></canvas>*@
        <!--由于是要展示所有面面,所以所有页面都分别绑定一个canvas-->
        <canvas ref="pdf-canvas" v-for="num in pdfPages"></canvas>
    </div>
</el-dialog>

绑定的Vue Data:

javascript 复制代码
data: function() {
    return {
        pdffile: {},
        isPDFVisible: false,
        pdfPages: 0,
        ..........
    }
}

要展示的文件这里集成在一个上传组件中,如代码所示:

html 复制代码
<el-form-item label="附件" prop="FileIDsArray">
    <div style="max-height:512px;overflow-x:auto;">
        <el-upload ref="upload_attach" :file-list="editForm.FileInfos" drag list-type="picture-card" multiple :limit="maxUpload" :on-exceed="handleExceed"
                   :action="uploadUrl" :auto-upload="autoupload" @*:headers="headers"*@ :data="uploadParam" :on-change="handleChange1" :before-upload="beforeUpload"
                   :on-success="uploadSuccess1" @*:on-preview="previewPic"*@ :on-remove="removeAttachFile1" :before-remove="beforeRemove" :class="{hideUnload:notAttachUploader}">
            @*<em class="el-icon-plus"></em>*@
            <em class="el-icon-upload"></em>
            <div class="el-upload__text">将文件拖到此处,或<em>点击上传</em></div>

            <div slot="file" slot-scope="{file}">
                @*<img class="el-upload-list__item-thumbnail"
                    :src="file.url" alt="">*@
                <span>{{file.name}}</span>
                <span class="el-upload-list__item-actions">
                    <span class="el-upload-list__item-preview" style="font-size: inherit;" v-show="!!file && file.name.slice(-4).toLowerCase()=='.pdf'"
                          @@click="handleViewFile(file)">
                        <i class="el-icon-zoom-in"></i>
                    </span>
                    <span class="el-upload-list__item-delete"
                          @@click="handleDownload(file)">
                        <i class="el-icon-download"></i>
                    </span>
                    <span class="el-upload-list__item-delete"
                          @@click="$refs.upload_attach.$refs['upload-inner'].onRemove(file);">
                        <i class="el-icon-delete"></i>
                    </span>
                </span>
            </div>

        </el-upload>
    </div>
</el-form-item>

重点是在显示PDF文件内容的方法------handleViewFile(file):

javascript 复制代码
handleViewFile: function (file) {
    var pThis = this;
    this.pdffile = file;
    this.isPDFVisible = true;
    this.$nextTick(function () {
        //const canvas = document.getElementById('pdf-canvas');
        pdfjsLib.getDocument(file.url).promise.then(function (pdfDoc) {
            pThis.pdfPages = pdfDoc.numPages;
            //由于canvas.getContext('2d')必须是在生成DOM并显示的情况下操作,由此需先"isPDFVisible=true"显示出组件,并在$nextTick完成DOM加载后再处理pdf内容的渲染:
            pThis.$nextTick(function () {
                for (var i = 1; i <= pThis.pdfPages; i++) {
                    const canvas = pThis.$refs["pdf-canvas"][i - 1];
                    pdfDoc.getPage(i).then(function (page) {
                        const viewport = page.getViewport({ scale: 1 });
                        const context = canvas.getContext('2d');
                        canvas.height = viewport.height;
                        canvas.width = viewport.width;
                        page.render({
                            canvasContext: context,
                            viewport: viewport
                        });
                    });
                }
            });
        });
    });
},

参考文章:

PDF.js 示例简介:

https://blog.csdn.net/github_36738403/article/details/131325145

如何显示整体PDF(不仅仅是一页)PDF.JS:

https://www.codenong.com/cs108161952/

相关推荐
vx_bisheyuange20 分钟前
基于SpringBoot的青年公寓服务平台
前端·vue.js·spring boot·毕业设计
奶糖 肥晨28 分钟前
JS自动检测用户国家并显示电话前缀教程|vue uniapp react可用
javascript·vue.js·uni-app
啊花是条龙44 分钟前
《产品经理说“Tool 分组要一条会渐变的彩虹轴,还要能 zoom!”——我 3 步把它拆成 1024 个像素》
前端·javascript·echarts
青茶3601 小时前
【js教程】如何用jq的js方法获取url链接上的参数值?
开发语言·前端·javascript
文艺理科生2 小时前
Google A2UI 解读:当 AI 不再只是陪聊,而是开始画界面
前端·vue.js·人工智能
晴栀ay2 小时前
React性能优化三剑客:useMemo、memo与useCallback
前端·javascript·react.js
知其然亦知其所以然2 小时前
别再死记硬背了,一篇文章搞懂 JS 乘性操作符
前端·javascript·程序员
json{shen:"jing"}2 小时前
08_组件基础
前端·javascript·vue.js
菩提祖师_2 小时前
基于VR的虚拟会议系统设计
开发语言·javascript·c++·爬虫
浮尘20252 小时前
PC端pdf软件测评
pdf·软件评测