uniapp h5本地预览pdf教程 (含白屏|跨域解决方案)

第一步 下载pdf.js

很多pdf.js版本在真机ios环境都会白屏

经测试后2.5.207版本比较稳定,Android和IOS环境PDF文件都能加载成功

下载地址
https://github.com/mozilla/pdf.js/releases/tag/v2.5.207https://github.com/mozilla/pdf.js/releases/tag/v2.5.207
第二步 解压移动pdfjs文件至项目中

在根目录static中创建html文件夹 , 将解压出来的pdfjs文件移动至html文件夹目录下

第三步 创建pdf文件预览页面preview.vue

远程pdf文件地址可能会有跨域问题,这里使用转文件流的方式进行处理,可根据实际业务逻辑改写

复制代码
<template>
	<web-view :src="pdfUrl" v-if="pdfUrl"></web-view>
</template>

<script>
	import request from '@/common/request.js';
	export default {
		data() {
			return {
				viewerUrl: '/static/html/web/viewer.html', //用来渲染PDF的html
				pdfUrl: '' // 最终显示在web-view中的路径
			}
		},
		onLoad(option) {
			console.log('=>进入了PDF预览页面')
			console.log('获取的参数=>', option,decodeURIComponent(option.src))
			let url = decodeURIComponent(option.src)
			let data = {
				url
			}
			uni.showLoading({
				mask:true
			})
			//使用pdf网络地址请求文件流信息,解决跨域问题
			uni.request({
			        url:request.baseUrl+'/h5/loadByUrl', //域名拼接
			        data: data,
			        method: 'post',
					responseType: 'arraybuffer', //这里记得设置响应数据格式,不然预览的pdf是空白
			        header: {
			          "authorization": uni.getStorageSync('token') // 携带的token
			        },
			        success: (response) => {
						uni.hideLoading()
						console.log(response)
						let pdfData = response.data; //pdfData是后端返回的文件流	
						//创建blob数据流
						let blob = new Blob([ pdfData], {
						    type: 'application/pdf;charset=UTF-8'
						})
						pdfData = window.URL.createObjectURL(blob)
						this.pdfUrl = `${this.viewerUrl}?file=${decodeURIComponent(pdfData)}`;
					},
			})
			//若没有pdf网络地址跨域问题可直接加载pdf
			// this.pdfUrl = `${this.viewerUrl}?file=${decodeURIComponent(url)}`;
		},
	}
</script>

第四步 实际场景中获取pdf地址并跳转至预览页

复制代码
uni.navigateTo({
		url:`/pages/index/preview?src=${encodeURIComponent(pdf网络地址)}`
})

预览效果

相关推荐
iOS阿玮4 小时前
不踩坑!苹果开发者账号:公司号和个人号,到底该怎么选?
uni-app·app·apple
2501_915106325 小时前
如何查看手机使用记录:Android和iOS设备全面指南
android·ios·智能手机·小程序·uni-app·iphone·webview
Ron丶7 小时前
10 款 PDF 处理工具(全解锁 · 免费使用)
pdf
刻刻帝的海角9 小时前
基于UniApp与Vue3语法糖的实时任务管理应用开发实践
uni-app
能不能送我一朵小红花10 小时前
基于uniapp的PDA手持设备红外扫码方案
前端·uni-app
chaffererdog10 小时前
uniapp开发微信小程序使用vk-uview-ui的uSearch搜索组件,在微信开发者工具中点击输入框会意外触发custom事件
微信小程序·小程序·uni-app
烂不烂问厨房10 小时前
前端实现docx与pdf预览
前端·javascript·pdf
脾气有点小暴12 小时前
uniapp通用递进式步骤组件
前端·javascript·vue.js·uni-app·uniapp
一晌小贪欢13 小时前
【静态功能网站】构建高效的 Markdown 转 PDF 在线工具
pdf·markdown·markdown转pdf·markdown 转 pdf
草字14 小时前
uniapp 滚动到表单的某个位置,表单验证失败时。
前端·javascript·uni-app