如何解决安卓手机无法预览pdf文件而是需要直接下载的问题

在开发中常常会遇到需要在一个应用里打开一份pdf文件并预览,经真机调试时发现在苹果手机上打开pdf文件能正常预览,但在安卓手机打开时却会需要我们下载才能预览,无法直接预览

为了解决这个问题,我们采用安装pdfH5插件的方式,代码如下:

1、安装pdfh5插件

npm i -S pdfh5

2、构建一个pdhH5组件

javascript 复制代码
<script>
import { computed, onMounted } from "vue";
import { useRoute } from 'vue-router'

import Pdfh5 from "pdfh5";
import "pdfh5/css/pdfh5.css";

export default {
  beforeRouteEnter: (to, from, next) => {
    if (to.query.name) {
      to.name = to.query.name
    }
    next()
  },
  setup() {
    const route = useRoute()
    onMounted(() => {
        let pdfurl = decodeURIComponent(route.query.pdfUrl)
        let pdfh5 = null

        //实例化
        pdfh5 = new Pdfh5("#PDF", {
            pdfurl: pdfurl,
        });

    });
  },
};
</script>

<template>
  <div id="PDF" class="view-pdf"></div>
</template>

<style lang="scss" scoped>
.view-pdf {
  width: 100%;
  height: 100vh;
}
</style>

3、在路由文件引入pfdH5组件

javascript 复制代码
{
	path: 'pdfView'
	name:'pdfView',
	component: () => import('../components/pdfH5.vue')
}

4、在业务组件跳转到pdfH5组件

javascript 复制代码
const handleClickPdf = () => {
	router.push({
		path:'/xxx/pdfview'
		query: {
			// pdfUr1是需要跳转的pdf文件的静态资源所在地址
			// name是浏览器顶部显示的文件标题
			pdfUr1: encodeURIComponent('xxx/xxx'),
			name: '条款及细则',
		}
	})
}
相关推荐
大G哥30 分钟前
Kotlin Lambda语法错误修复
android·java·开发语言·kotlin
AORO_BEIDOU1 小时前
遨游科普:2025年,三防平板有多智能?
网络·人工智能·安全·智能手机·电脑·信息与通信
鸿蒙布道师4 小时前
鸿蒙NEXT开发动画案例2
android·ios·华为·harmonyos·鸿蒙系统·arkui·huawei
androidwork4 小时前
Kotlin Android工程Mock数据方法总结
android·开发语言·kotlin
秋名RG5 小时前
PDF生成模块开发经验分享
经验分享·pdf
xiangxiongfly9156 小时前
Android setContentView()源码分析
android·setcontentview
人间有清欢7 小时前
Android开发补充内容
android·okhttp·rxjava·retrofit·hilt·jetpack compose
人间有清欢8 小时前
Android开发报错解决
android
混吃等死的牛9 小时前
PPT画图导出为PDF格式
pdf·powerpoint
HMS Core9 小时前
【FAQ】HarmonyOS SDK 闭源开放能力 — PDF Kit
华为·pdf·harmonyos