项目中的附件列表,通常情况都需要提供下载、删除的功能,功能本身没有什么要说的,都是基本功能,使用浏览器的的下载功能,也都是用window.open(url),或者window.location.href=url的方式,url即为附件下载接口,浏览器自动解析,如果是图片、视频、txt等格式的会直接预览文件,而不是像docx、xlsx一样直接下载,项目中为了功能明确,将预览单独加了一个查看按钮,下载按钮要实现无论什么文件格式都直接下载。

有两种方式处理:
一.后台接口层面处理:(比较常见)
响应头中添加标识:
Response.AddHeader("Content-Disposition", "attachment; filename=" +
HttpUtility.UrlEncode(annotation.FileName, System.Text.Encoding.UTF8));

添加后,浏览器就会全都直接下载,不区分文件格式

二.前端JS使用XMLHttpRequest结合download.js处理

1)首先页面中需要引用download.js

download官方:http://danml.com/download.html

http://danml.com/js/download2.js

2)公共方法

 1  /*
2 * 使用download.js 强制浏览器下载图片、视频等文件
3 * @param {any} url url链接地址
4 * @param {any} strFileName 文件名
5 * @param {any} strMimeType 文件类型
6 * dzl
7 * 2020年5月8日
8 */
9 function downloadfile(url, strFileName, strMimeType) {
10 var xmlHttp = null;
11 if (window.ActiveXObject) {
12 // IE6, IE5 浏览器执行代码
13 xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
14 } else if (window.XMLHttpRequest) {
15 // IE7+, Firefox, Chrome, Opera, Safari 浏览器执行代码
16 xmlHttp = new XMLHttpRequest();
17 }
18 //2.如果实例化成功,就调用open()方法:
19 if (xmlHttp != null) {
20 xmlHttp.open("get", url, true);
21 xmlHttp.responseType = 'blob';//关键
22 xmlHttp.send();
23 xmlHttp.onreadystatechange = doResult; //设置回调函数
24 }
25 function doResult() {
26 if (xmlHttp.readyState == 4) { //4表示执行完成
27 if (xmlHttp.status == 200) { //200表示执行成功
28 download(xmlHttp.response, strFileName, strMimeType);
29 }
30 }
31 }
32 }

注意: xmlHttp.responseType = 'blob';是关键,必须要设置

3)下载按钮点击事件中调用公共方法

downloadfile(url, filename, getFileType(filename))

附上根据文件名的尾缀 返回文件类型的公共方法:

 1 /*
2 * 根据文件名的尾缀 返回文件类型
3 * @param {any} fileName 文件名
4 * dzl
5 * 2020年5月9日
6 */
7 function getFileType(fileName) {
8 // 后缀获取
9 let suffix = '';
10 // 获取类型结果
11 let result = '';
12 try {
13 const flieArr = fileName.split('.');
14 suffix = flieArr[flieArr.length - 1];
15 } catch (err) {
16 suffix = '';
17 }
18 // fileName无后缀返回 false
19 if (!suffix) { return false; }
20 suffix = suffix.toLocaleLowerCase();
21 // 图片格式
22 const imglist = ['png', 'jpg', 'jpeg', 'bmp', 'gif'];
23 // 进行图片匹配
24 result = imglist.find(item => item === suffix);
25 if (result) {
26 return 'image';
27 }
28 // 匹配txt
29 const txtlist = ['txt'];
30 result = txtlist.find(item => item === suffix);
31 if (result) {
32 return 'txt';
33 }
34 // 匹配 excel
35 const excelist = ['xls', 'xlsx'];
36 result = excelist.find(item => item === suffix);
37 if (result) {
38 return 'excel';
39 }
40 // 匹配 word
41 const wordlist = ['doc', 'docx'];
42 result = wordlist.find(item => item === suffix);
43 if (result) {
44 return 'word';
45 }
46 // 匹配 pdf
47 const pdflist = ['pdf'];
48 result = pdflist.find(item => item === suffix);
49 if (result) {
50 return 'pdf';
51 }
52 // 匹配 ppt
53 const pptlist = ['ppt', 'pptx'];
54 result = pptlist.find(item => item === suffix);
55 if (result) {
56 return 'ppt';
57 }
58 // 匹配 视频
59 const videolist = ['mp4', 'm2v', 'mkv', 'rmvb', 'wmv', 'avi', 'flv', 'mov', 'm4v'];
60 result = videolist.find(item => item === suffix);
61 if (result) {
62 return 'video';
63 }
64 // 匹配 音频
65 const radiolist = ['mp3', 'wav', 'wmv'];
66 result = radiolist.find(item => item === suffix);
67 if (result) {
68 return 'radio';
69 }
70 // 其他 文件类型
71 return 'other';
72 }

部分技术参考:

https://www.cnblogs.com/allen0118/p/12793501.html

https://blog.csdn.net/u014643351/article/details/99303871

JS端实现图片、视频时直接下载而不是打开预览的更多相关文章

  1. 纯前端下载pdf链接文件,而不是打开预览的解决方案

    纯前端下载pdf链接文件,而不是打开预览的解决方案 一,介绍与需求 1.1,介绍 XMLHttpRequest 用于在后台与服务器交换数据.这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行 ...

  2. vue / js使用video获取视频时长

    项目中遇到上传视频功能,需要有预览和获取视频时长功能,因之前使用upload(有需要的话可以参考下我之前的文章),这里就不赘述,直接用来上传视频,不过在上传之前和上传成功后的钩子里,获取不到时长: 没 ...

  3. 图片上传,支持同步/异步、预览(MVC、uploadify异步提交、js预览、ajaxSubmit异步提交)兼容大部分浏览器,含代码

    图片上传代码,支持同步/异步和图片的预览 主要用了两种方式,可兼容大部分浏览器. 第一种使用uploadify异步上传,上传后返回图片路径显示到页面. 每二种使用ajaxSubmit异步上传,为兼容I ...

  4. axios 下载文件流或者预览在线pdf

    问题: 后端返回文件流,前端使用axios下载或者在线预览 下载文件流 import axios from 'axios' // 设置响应类型为blob axios.get('/api/app/xxx ...

  5. js实现图片选中马上显示功能,选择后可以预览,即选即显

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  6. window.open在打开pdf时直接下载而不是查看

    一般这是url请求的原因导致的, 可以考虑这种写法 window.open(link+'?response-content-type=application/pdf') 加上后面这段可以转为查看

  7. JS面向对象方法(二) 面向对象方法实现橱窗式图面预览以及放大功能

     效果图: HTML结构如下: <div id="preview"> <div id="mediumDiv"> <img id=& ...

  8. 有关谷歌下载PDF文件而不是直接打开预览的问题

    找了很多帖子,都不行, 解决方法把链接处理成blob文件再调用下载. 但是仍然不行,最终原因找到: 缺少了这一部创建,需要把二进制数据重新用 Blob对象申明下 let data = new Blob ...

  9. 利用vue-cropper做的关于图片裁剪、压缩、上传、预览等做的一个公共组件

    公共组件: <template> <div> <div class="upload-box"> <div class="imag ...

  10. 如何使 pdf 文件在浏览器里面直接下载而不是打开

    前言 在做需求过程中我们大概率会遇到在浏览器中下载文件的需求,如果仅仅是这个要求的话很简单,有如下两种解决方式. 第一种是通过 window 对象的 open 方法进行操作,将文件 url 直接在浏览 ...

随机推荐

  1. Java 面向对象高级

    文章目录 1.静态 1.1 static修饰成员变量 1.2 static修饰成员变量的应用场景 1.3 static修饰成员方法 1.4 工具类 1.5 static的注意事项 1.6 static ...

  2. 使用netsh命令行进行网络管理

    显示网络适配器状态 netsh interface show interface 显示各个网络适配器的名称和状态 启用(禁用)网络适配器 本系列命令需要以"以管理员身份运行". 禁 ...

  3. PME算法简单Python实现

    技术背景 在前面的两篇博客中,我们分别介绍了Ewald算法求解静电势能和基于格点拉格朗日插值法的PME算法.在多种计算优化算法(Ewald求和.快速傅里叶变换.格点拉格朗日插值.截断近似)的加持下,使 ...

  4. MarkDown用法学习笔记

    标题: 用 '#'标识,可以到从1到6级标题设置,有多少个'#'符号就对应多少级标题 粗体: 用''标识,如果两边只有一个''标识是斜体,如果两有2个这符号标题是加粗,如果有3个这符号标识是斜体和加粗 ...

  5. 使用Roslyn的源生成器生成DTO

    前言 源生成器的好处很多, 通过在编译时生成代码,可以减少运行时的反射和动态代码生成,从而提高应用程序的性能, 有时候需要对程序AOT以及裁剪编译的dll也是需要用SG来处理的. 我们开发程序应该都绕 ...

  6. Minio安装以及使用

    Minio介绍 MinIO 是一个基于Apache License v2.0开源协议的对象存储服务.适合于存储大容量非结构化的数据,例如图片.视频.日志文件.备份数据和容器/虚拟机镜像等,而一个对象文 ...

  7. 鸿蒙NEXT开发案例:计数器

    [引言](完整代码在最后面) 本文将通过一个简单的计数器应用案例,介绍如何利用鸿蒙NEXT的特性开发高效.美观的应用程序.我们将涵盖计数器的基本功能实现.用户界面设计.数据持久化及动画效果的添加. [ ...

  8. 【昌哥IT课堂】MySQL8.3 EXPLAIN中的新JSON格式(译)

    MySQL提供了两个用于分析查询计划的强大工具:EXPLAIN和EXPLAIN ANALYZE.EXPLAIN显示优化器选择的执行计划,并在执行之前停止,而EXPLAIN ANALYZE实际执行查询并 ...

  9. mongodb之进阶

    常用命令: 1.查看数据库空间大小 db.stats(); 默认是bytes单位 { "db" : "xxx", //当前数据库 "collectio ...

  10. Linux之命令提示神器tldr

    github:tldr-pages/tldr: Collaborative cheatsheets for console commands (github.com) 一款很好用的命令帮助工具, 之前 ...