如何解决安卓手机无法预览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: '条款及细则',
		}
	})
}
相关推荐
私人珍藏库1 小时前
【Android】Soul v5.86.0 内置模块版
android·app·工具·软件·多功能
千里马学框架2 小时前
aosp新增窗口层级 Type 完整实现方案(有源码)-wms需求和面试题
android·智能手机·架构·wms·aaos·车机
峥嵘life7 小时前
Android 蓝牙设备连接广播详解-2026
android·python·学习
MusingByte10 小时前
别再裸用 Claude Code 了!安卓开发者必装 13 个官方推荐插件,效率翻 3 倍省 70% token
android
_李小白10 小时前
【android opencv学习笔记】Day 29: 滤波算法之Sobel 边缘检测
android·opencv·学习
Dxy123931021611 小时前
Python 操作 MySQL 事务:从入门到避坑
android·python·mysql
峥嵘life12 小时前
Android getprop 属性限制详解:User 版本属性获取问题分析
android·开发语言·python·学习
呉師傅13 小时前
联想ideapad 310-15ABR拔掉充电器使用电池工作花屏问题的解决方法【维修个例】
运维·服务器·网络·智能手机·电脑
古月开发13 小时前
旧手机变身 AI 作业监督器:低成本家庭学习解决方案
人工智能·学习·智能手机
一航jason13 小时前
Speed Tools:一套低侵入的 Android 插件化 + 动态换肤 + 字体切换框架
android·插件化·组件化·换肤