前端实现首次访问,后续从本地访问

server/2024/9/20 7:07:37/ 标签: 前端

前端实现将PDF文件下载到用户的本地磁盘,并在后续加载时使用本地文件,而不是重新从服务器下载,可以通过以下步骤实现:
1. **使用`<a>`标签的`download`属性**:当用户首次点击下载PDF时,通过`<a>`标签将PDF文件保存到用户的设备上。
2. **保存下载链接**:将下载PDF的链接保存到LocalStorage中,以便后续可以检查是否已经下载过该文件。
3. **检测本地文件**:在尝试加载PDF之前,检查LocalStorage中是否有下载链接,如果有,则提示用户打开已下载的文件。
以下是一个简单的实现示例:
### HTML
```html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>PDF Download and Cache Example</title>
</head>
<body>
<button id="downloadPdf">下载PDF</button>
<script src="pdfDownloadCache.js"></script>
</body>
</html>
```
### JavaScript (pdfDownloadCache.js)
```javascript
document.getElementById('downloadPdf').addEventListener('click', function() {
    const pdfName = 'example.pdf';
    const storageKey = `pdf-${pdfName}`;
    // 检查LocalStorage中是否已有下载链接
    if (localStorage.getItem(storageKey)) {
        console.log('PDF has been downloaded before. Please open it from your downloads folder.');
        // 这里可以提供一个打开文件的方法,但这通常需要用户手动操作
    } else {
        console.log('Downloading PDF for the first time.');
        downloadPdf(pdfName, storageKey);
    }
});
function downloadPdf(pdfName, storageKey) {
    const downloadLink = document.createElement('a');
    downloadLink.href = pdfName; // 假设这是PDF文件的URL
    downloadLink.download = pdfName; // 设置下载文件名
    document.body.appendChild(downloadLink);
    downloadLink.click();
    // 保存下载链接到LocalStorage
    localStorage.setItem(storageKey, pdfName);
    // 清理DOM
    document.body.removeChild(downloadLink);
}
```
**注意事项**:
- 使用`<a>`标签的`download`属性来触发下载不会在用户的设备上创建指向文件的链接,因此无法直接在前端代码中打开已下载的文件。用户需要手动到下载文件夹中打开文件。
- 如果PDF文件是从不同的源(即跨域)加载的,浏览器可能会阻止下载操作,因为同源策略的限制。
- 如果您希望能够在浏览器中直接打开已下载的PDF文件,而不是让用户去下载文件夹中找,那么这通常是不可能的,因为浏览器的安全限制。不过,您可以在用户的设备上保存PDF文件的引用,并在用户下次访问时提示他们打开,但这需要用户手动操作。
以上方法是在前端代码中处理下载逻辑,实际上打开本地文件的操作通常需要用户自己来完成。如果需要在网页中直接显示PDF文件,而不依赖于本地下载,则通常需要将PDF文件保存在服务器上,并通过前端代码加载显示。

 


http://www.ppmy.cn/server/104946.html

相关文章

私有仓库tomcat镜像构建

通过Tomcat安装包构建镜像 Dockerfile # 使用官方的OpenJDK镜像作为基础镜像 FROM xa-test.harbor.com:55555/idaas/openjdk:8u232 ENV CATALINA_HOME/usr/local/tomcat ENV PATH$CATALINA_HOME/bin:$PATH # 将Tomcat的压缩包复制到镜像中并解压到指定目录 COPY apache-tomcat…

Apollo9.0 PNC源码学习之Planning模块—— Lattice规划(六):横纵向运动轨迹评估

参考文章: (1)Apollo6.0代码Lattice算法详解——Part6:轨迹评估及碰撞检测对象构建 (2)自动驾驶规划理论与实践Lattice算法详解 0 前言 横纵向运动轨迹的评估,主要通过构建定点巡航和定点停车两个场景下,对纵向运动参考速度、加速度、加加速度的大小进行检验和过滤,然…

1.初识redis

文章目录 1.认识redis1.1 mysql和redis 对比1.2分布式系统1.2.1单机架构与分布式架构1.2.2数据库分离(应用服务器和存储服务器分离)与负载均衡1.2.3负载均衡器1.2.4 数据库读写分离1.2.5 数据库服务器引入缓存1.2.6数据库分库分表1.2.7 引入微服务 2.常见概念解释2.1 应用(Appl…

JDK15.0.2安装

JDK15.0.2安装 1. 下载 下载地址&#xff1a; https://www.oracle.com/java/technologies/downloads/archive/ 通过百度网盘分享的文件&#xff1a;jdk-15.0.2_windows-x64_bin.exe 链接&#xff1a;https://pan.baidu.com/s/15AOcTby3YLSp26_btCkEIw 提取码&#xff1a;vs7…

10. 指针数组和数组指针详细区别

指针数组和数组指针在存储位置和占用内存大小方面也有显著的区别&#xff0c;尤其是它们的结构不同导致内存分布上的差异。接下来详细说明它们在这两个方面的区别&#xff1a; 1. 指针数组 (Array of Pointers) 定义回顾&#xff1a; int *array[5];这里 array 是一个指针数…

K8S部署MySQL5.7的主从服务

mysql-slave-0是master mysql-slave-1是备份 当mysql写的时候&#xff0c;找headless service中的 mysql-slave-0.mysql57-slave-headless&#xff1b;当mysql读的时候&#xff0c;找clusterip service中的mysql57-slave-read读&#xff0c;实现读写分离。 statefulset维护两个…

Spring + Boot + Cloud + JDK8 + Elasticsearch 单节点 模式下实现全文检索高亮-分页显示 快速入门案例

1. 安装elasticsearchik分词器插件 sudo wget https://release.infinilabs.com/analysis-ik/stable/elasticsearch-analysis-ik-8.13.4.zip sudo mkdir -p ./es_plugins/analysis-ik sudo mkdir ./es_data sudo unzip elasticsearch-analysis-ik-8.13.4.zip -d ./es_plugins/a…

探索提示工程 Prompt Engineering的奥妙

一、探索提示工程 1. 介绍通用人工智能和专用人工智能 人工智能&#xff08;AI&#xff09;可以分为通用人工智能&#xff08;AGI&#xff09;和专用人工智能&#xff08;Narrow AI&#xff09;。AGI是一种能够理解、学习和执行任何人类可以完成的任务的智能。与此相对&#x…

Neo4j 图数据库入门

图形数据库存储节点和关系&#xff0c;而不是表或文档。数据的存储方式就像你在白板上勾画想法一样。您的数据存储不受预定义模型的限制&#xff0c;允许以非常灵活的方式考虑和使用它。 一、核心概念&#xff1a;属性图形模型 Neo4j使用属性图数据库模型。图数据结构由节点(离…

【图形学】TA之路-基于Unity Shader编程之初体验

学习shader之前你必须知道的事情&#xff1a; Unity开发引擎、Direct3D、Shader他们之间的关系 Direct3D 是一个底层图形 API&#xff0c;它直接与 GPU &#xff08;显卡&#xff09;交互&#xff0c;提供了访问硬件加速功能的接口。Unity 开发引擎&#xff0c;它封装了很多底…

自然语言处理系列三十九》条件随机场CRF算法原理

注&#xff1a;此文章内容均节选自充电了么创始人&#xff0c;CEO兼CTO陈敬雷老师的新书《自然语言处理原理与实战》&#xff08;人工智能科学与技术丛书&#xff09;【陈敬雷编著】【清华大学出版社】 文章目录 自然语言处理系列三十九条件随机场(CRF)算法原理CRF与HMM 总结 …

【LeetCode每日一题】——1046.最后一块石头的重量

文章目录 一【题目类别】二【题目难度】三【题目编号】四【题目描述】五【题目示例】六【题目提示】七【解题思路】八【时间频度】九【代码实现】十【提交结果】 一【题目类别】 优先队列 二【题目难度】 简单 三【题目编号】 1046.最后一块石头的重量 四【题目描述】 有…

【Java 搜索二维矩阵 I II,多数元素 I II,分治法 二分法 摩尔投票法】

搜索二维矩阵 I II&#xff0c;多数元素&#xff0c;分治法 & 二分法 & 摩尔投票法 题目1&#xff1a;力扣-搜索二维矩阵[https://leetcode.cn/problems/search-a-2d-matrix/description/](https://leetcode.cn/problems/search-a-2d-matrix/description/)分治-排除法分…

电脑无法新建 Word Excle PPT 这些文件是咋回事

咦 我的电脑怎么没有 Excel文件 Word文件 和 PPT选项嘞 &#xff01;&#xff01; 今天突然要写个材料&#xff0c;发现自己新建文件竟然没有excel文档 word和ppt幻灯片这些选项。哦 原来是我自己上次把电脑从win7升级win10系统之后还没有安装wps这些所以不能使用。如果你的电…

【c++】强制类型转化

一、前言 在C语言中新增了四个关键字static_cast、const_cast、reinterpret_cast和dynamic_cast。这四个关键字都是用于强制类型转换的。 新类型的强制转换可以提供更好的控制强制转换过程&#xff0c;允许控制各种不同种类的强制转换。 C中风格是static_cast<type>(c…

ARM/Linux嵌入式面经(二六):韶音

面试体验很好,流程规范,HR细心热情,目前秋招体验最好的一家公司。 一面HR面30min: 1.自我介绍 2.课题组主要做的什么方向 3.聊一聊项目,内容,团队,分工 4.课题组多少人等等。。 5.唠家常 6.其他公司进度 7.意向薪资 二面技术面20min 1.自我介绍 2.OTA 在嵌入式…

linux tomcat jenkins 迁移

最近由于我们的测试和生产环境jenkins频频发生错误&#xff0c;索性尝试了一把在阿里云上做jenkins迁移 在阿里云jenkins安装模式是用tomcat安装部署的 [rootk8s-master local]# ls aegis bin cloudmonitor etc games go ilogtail include lib lib64 libexec sbin…

高性能Web服务器

Nginx的架构和安装Nginx的概述 Nginx &#xff1a; engine X &#xff0c; 2002 年开发&#xff0c;分为社区版和商业版 (nginx plus ) 2019 年 3 月 11 日 F5 Networks 6.7 亿美元的价格收购 Nginx 是免费的、开源的、高性能的 HTTP 和反向代理服务器、邮件代理服务器、以及 T…

【Qt笔记】QPushButton控件详解

目录 一、概述 二、属性 三、方法 四、信号与槽 五、QPushButton的主要功能 六、QPushButton的常用函数方法 1. 构造函数 2. 设置与获取文本 3. 设置与获取图标 4. 设置与获取快捷键 5. 连接信号和槽 6. 启用和禁用按钮 7. 设置默认按钮和自动默认按钮 七、QPush…

DM8守护集群部署、数据同步验证、主备切换

1. 环境描述 实例详情 端口详情 2. 部署步骤 2.1 数据准备 2.1.1主库初始化 [dmdbaray1 ~]$ cd /dmdba/dmdbms/bin [dmdbaray1 bin]$ ./dminit path/dmdba/data PAGE_SIZE32 EXTENT_SIZE32 CASE_SENSITIVEy CHARSET1 DB_NAMEGRP1_RT_01 INSTANCE_NAMEGRP1_RT_01 PORT_NU…