zoukankan      html  css  js  c++  java
  • Vue pdf 多文件全部页面显示 使用笔记

    pdf 多文件显示全部显示

    参考链接

    https://github.com/FranckFreiburger/vue-pdf#createloadingtasksrc

    单个文件

    安装

    npm install --save vue-pdf
    

    单个pdf文件显示全部,我是直接复制的参考链接

    <template>
    	<div>
    		<pdf
    			v-for="i in numPages"
    			:key="i"
    			:src="src"
    			:page="i"
    			style="display: inline-block;  25%"
    		></pdf>
    	</div>
    </template>
    
    <script>
    
    import pdf from 'vue-pdf'
    
    var loadingTask = pdf.createLoadingTask('https://cdn.mozilla.net/pdfjs/tracemonkey.pdf');
    
    export default {
    	components: {
    		pdf
    	},
    	data() {
    		return {
    			src: loadingTask,
    			numPages: undefined,
    		}
    	},
    	mounted() {
    
    		this.src.promise.then(pdf => {
    
    			this.numPages = pdf.numPages;
    		});
    	}
    }
    
    </script>
    

    多个pdf文件 全部显示

    效果预览

    多pdf文件全部预览

    有几个点要注意

    • 一 本地pdf文件的话,pdf文件必须放置在 public (vue-cli 4+) 或者 static (vue-cli < 3) 文件夹下, 如果放置src/assets下, 会读取报错,下面demo pdf文件放置在public下

    • 二 使用线上的pdf文件时,需要后台配合处理跨域,否则读取不了pdf文件。

    • 三 得使用async/await语法糖取出promise对象里面的pdf总页数。

    <template>
        <div class="about">
            <template v-for="item in handelPdfList">
                <pdf
                        v-for="i in item.numPages"
                        :key="i"
                        :src="item.src"
                        :page="i"
                        style="display: inline-block;  25%"
                ></pdf>
            </template>
        </div>
    </template>
    <script>
        import pdf from 'vue-pdf'
    
    
        export default {
            name: "about",
            components: {
                pdf
            },
            data() {
                return {
                    // src: loadingTask,
                    numPages: undefined,
                    pdfList: [
                        {
                            src: '/test.pdf'
                        },
                        {
                            src: '/test.pdf'
                        }
                    ],
                    handelPdfList: []
                }
            },
            mounted() {
                this.handelPdf()
            },
            methods: {
                async handelPdf() {
                    for (let info of this.pdfList) {
                        // 测试使用本地的pdf文件 (必须放到public(vue-cli 4+)或者static文件里面)
                        // info.src = '/test.pdf'
                        // 测试使用 自己搭建 已跨域的pdf文件
                        // info.src = 'http://127.0.0.1:8010/assets/test.pdf'
                        info['numPages'] = await pdf.createLoadingTask(info.src).promise.then(pdf => {
                            return pdf.numPages
                        })
                    }
                    // 数据处理完毕后  再复制
                    this.handelPdfList = this.pdfList
                }
            }
        }
    </script>
    
    
  • 相关阅读:
    咖啡叫软件开发--界面组日志06-总结
    咖啡叫软件开发--界面组日志05
    咖啡叫软件开发--界面组日志04
    咖啡角软件开发--界面组日志03
    咖啡角软件开发--界面组日志02
    咖啡角软件开发--界面组日志01
    实时控制软件 第三次作业
    第二次作业
    《构建之法:现代软件工程》第一章有感
    第一天
  • 原文地址:https://www.cnblogs.com/CharmCode/p/13599243.html
Copyright © 2011-2022 走看看