位置: IT常识 - 正文

vue关于下载文件常用的几种方式(vue文件下载功能)

编辑:rootadmin
这篇文章主要介绍了vue关于下载文件常用的几种方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教 目录

推荐整理分享vue关于下载文件常用的几种方式(vue文件下载功能),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue下载项目中的文件,vue实现文件下载功能,vue实现下载文件,vue文件下载功能,vue中下载文件,vue实现文件下载功能,vue文件下载直接在界面展示,vue实现文件下载功能,内容如对您有帮助,希望把文章链接给更多的朋友!

vue下载文件常用方式直接打开我们可以自己封装一个方法vue常用的命令创建vue项目常用命令vue项目部署启动项目总结vue下载文件常用方式直接打开

直接打开是指我们直接使用window.open(URL)的方法

优点:简单操作缺点:没办法携带token我们可以自己封装一个方法

比如如下:

import axios from "axios"import * as auth from '@/utils/auth.js'let ajax = axios.create({    baseURL: process.env.VUE_APP_BASE_API,    timeout: 100000});ajax.interceptors.request.use(config => {        config.headers = {            Authorization: auth.getToken(),            // OrgId: auth.getUser().orgId,            // UserId: auth.getUser().id,        }        return config    },    err => {        return Promise.reject(err)    })let downloadFile = async (url, formData, options) => {    await ajax.post(url, formData, {responseType: 'arraybuffer'}).then(resp => download(resp, options))}let getFile = async (url, options) => {    await ajax.get(url, {responseType: 'blob'}).then(resp => download(resp, options))}let download = (resp, options) => {    let blob = new Blob([resp.data], {type: options.fileType ? options.fileType : 'application/octet-binary'})    //创建下载的链接    let href = window.URL.createObjectURL(blob)    downloadBlob(href, options.fileName)}let downloadBlob = (blobUrl, fileName, revokeObjectURL) => {    let downloadElement = document.createElement('a')    downloadElement.href = blobUrl    //下载后文件名    downloadElement.download = fileName    document.body.appendChild(downloadElement)    //点击下载    downloadElement.click()    //下载完成移除元素    document.body.removeChild(downloadElement)    if (revokeObjectURL == null || revokeObjectURL) {        //释放掉blob对象        window.URL.revokeObjectURL(blobUrl)    }}let getDownloadFileUrl = async (url, fileType) => {    let blob    await ajax.get(url, {responseType: 'blob'}).then(resp => {        blob = new Blob([resp.data], {type: fileType ? fileType : 'application/octet-binary'});    })    return window.URL.createObjectURL(blob);}let getDownloadFileUrlByPost = async (url, data, fileType) => {    let blob    await ajax.post(url, data, {responseType: 'blob'}).then(resp => {        blob = new Blob([resp.data], {type: fileType ? fileType : 'application/octet-binary'});    })    return window.URL.createObjectURL(blob);}let getDownloadFileBlob = async (url, fileType) => {    let blob    await ajax.get(url, {responseType: 'blob'}).then(resp => {        blob = new Blob([resp.data], {type: fileType ? fileType : 'application/octet-binary'});    })    return blob;}export default {    ajax,    downloadFile,    getFile,    getDownloadFileUrl,    getDownloadFileUrlByPost,    getDownloadFileBlob,    downloadBlob}

然后在我们调用的那个页面中直接引入使用就好啦

//先引用import ajax from '../../utils/ajax.js'//使用ajax.downloadFile('URL',null,{下载的文件名称})

这样看是不是就挺容易的

vue常用的命令创建vue项目常用命令

如果vue项目出错了你可以把依赖删掉,清理一下缓存在重新安装

清理缓存 npm cache clean --force

第一步,创建淘宝镜像,安装npm镜像(如果已经安装的就直接第二步就可以了)

npm install -g cnpm --registry=https://registry.npm.taobao.org

第二步, 全局安装vue-vli

npm install --g vue-cli

第三步, 创建一个vue项目

vue init webpack 项目名

vue项目部署npm install启动项目npm run dev/npm run serve

1、安装element_ui

npm i element-ui -S

安装成功后在main.js中到导入element-ui,并使用

    import ElementUI from 'element-ui';    import 'element-ui/lib/theme-chalk/index.css';    Vue.use(ElementUI);

2、安装vue_router

npm install vue-router --save 

安装完成如果没有文件夹router(一般都有vue2.0下需要自己选择安装,vue3.0创建有)我们直接创建index.js文件。文件放入以下配置

import Vue from 'vue'import VueRouter from 'vue-router';Vue.use(VueRouter); import XXX "../src/components/xxx";  const routes = [  {    path:'/'    component: XXX  }, ] const router = new VueRouter({  routes}) export default router

要在main.js中应用router.js文件。我们需要在中放入router

import router from "../router";    new Vue({  router,  el: '#app',  components: { App },  template: '<App/>'})vue关于下载文件常用的几种方式(vue文件下载功能)

3、 安装axios组件,安装命令如下:

npm install --save vue-axios  

在main.js文件下引入如下代码:

import axios from 'axios'import VueAxios from 'vue-axios'Vue.use(VueAxios, axios)总结

1.安装vue-cli

npm install --global vue-cli

2.创建一个基于 webpack 模板的新项目

vue init webpack 项目名称

3.运行:npm run dev

4.安装依赖:cd 项目名称 npm install

5.安装vue-resource插件(通过XMLHttpRequest或JSONP发起请求并处理响应 //get post请求):npm install vue-resource --save

6.安装路由插件:

npm install vue-router --save

7.安装element-ui:

npm i element-ui -S(安装好之后要记得在main.js中引入)

8.安装axios npm install axios --save

9.安装Echarts npm install echarts --save

10.如果想要终止终端(cmd)正在运行的命令,则ctrl +c

11.安装指定版本jquery

npm i jquery@版本号

12.若项目中node_modules文件被删除,使用 npm install 即能把package.json中的dependencies中所有依赖项都下载回来

以上为个人经验,希望能给大家一个参考,也希望大家多多支持本站。

本文链接地址:https://www.jiuchutong.com/zhishi/304144.html 转载请保留说明!

上一篇:2022年可在苹果笔记本M1和M2芯片的Macos系统上运行的手机Alook浏览器-8倍速破解版-电脑学习网(苹果2021年在中国不能用了吗)

下一篇:时间格式的转换---全(时间格式转换成小时数)

  • oppo手机删除的视频怎么找回来(oppo手机删除的聊天记录怎么找回来)

    oppo手机删除的视频怎么找回来(oppo手机删除的聊天记录怎么找回来)

  • 申请退款了怎么卖家还发货怎么办(申请退款了怎么拒收快递)

    申请退款了怎么卖家还发货怎么办(申请退款了怎么拒收快递)

  • 红外测温仪显示lo是什么意思(红外测温仪显示er1)

    红外测温仪显示lo是什么意思(红外测温仪显示er1)

  • 40分钟视频如何发给好友(40分钟视频如何发给电脑)

    40分钟视频如何发给好友(40分钟视频如何发给电脑)

  • 512固态硬盘什么意思(512固态硬盘有什么用)

    512固态硬盘什么意思(512固态硬盘有什么用)

  • 人工智能是什么意思(人工智能是什么专业学的)

    人工智能是什么意思(人工智能是什么专业学的)

  • 淘宝评论删除了可以重新再评吗?(淘宝评论删除了还可以评论吗)

    淘宝评论删除了可以重新再评吗?(淘宝评论删除了还可以评论吗)

  • 网络丢包率多少算正常(网络丢包率100%)

    网络丢包率多少算正常(网络丢包率100%)

  • 电脑关机又开机怎么回事(电脑关机又开机如何修复)

    电脑关机又开机怎么回事(电脑关机又开机如何修复)

  • 升降摄像头坏了能修吗(升降摄像头坏了有必要修吗)

    升降摄像头坏了能修吗(升降摄像头坏了有必要修吗)

  • excel怎么把第一行固定在最上面(excel怎么把第一行固定在顶端)

    excel怎么把第一行固定在最上面(excel怎么把第一行固定在顶端)

  • 快手作品的访客记录能看到吗(快手作品的访客怎么看)

    快手作品的访客记录能看到吗(快手作品的访客怎么看)

  • iphone5像素多少万(苹果5c像素)

    iphone5像素多少万(苹果5c像素)

  • 不能采用顺序存储结构的是(顺序存储不需要连续的存储区域)

    不能采用顺序存储结构的是(顺序存储不需要连续的存储区域)

  • 拼多多怎么取消拼单(拼多多怎么取消免密支付)

    拼多多怎么取消拼单(拼多多怎么取消免密支付)

  • xsmax有没有抬头灯(苹果xsmax的抬头灯怎么开启)

    xsmax有没有抬头灯(苹果xsmax的抬头灯怎么开启)

  • 别人的抖音id怎么去掉(别人的抖音id怎么查)

    别人的抖音id怎么去掉(别人的抖音id怎么查)

  • 手机qq好友亲密度怎么涨(手机qq好友亲密度怎么关闭)

    手机qq好友亲密度怎么涨(手机qq好友亲密度怎么关闭)

  • iphone桌面添加小程序(iphone桌面如何添加小组件)

    iphone桌面添加小程序(iphone桌面如何添加小组件)

  • 数据化的意义(数据化的意义和作用)

    数据化的意义(数据化的意义和作用)

  • xsmax有红外功能吗(xsmax有没有红外)

    xsmax有红外功能吗(xsmax有没有红外)

  • 美团如何开会员(美团如何开会员卡)

    美团如何开会员(美团如何开会员卡)

  • 苹果xr语音助手在哪里(苹果xr语音助手怎么回事不能用)

    苹果xr语音助手在哪里(苹果xr语音助手怎么回事不能用)

  • 如何查找丢失的手机(如何查找丢失的耳机)

    如何查找丢失的手机(如何查找丢失的耳机)

  • Win7原版系统安装教程(超详细图文版)(win7原版系统安装后没有任何驱动)

    Win7原版系统安装教程(超详细图文版)(win7原版系统安装后没有任何驱动)

  • echo命令  输出字符串或提取后的变量值(echo输出语句)

    echo命令 输出字符串或提取后的变量值(echo输出语句)

  • 不得从销项税中抵扣的进项税大白话
  • acca b/f
  • 公司食堂菜金会计分录
  • 购买车辆保险的现金流
  • 企业筹建期间契税账务处理
  • 一般纳税人销售自己使用过的汽车
  • 兼营和混合销售的联系
  • 信用减值损失是什么类科目
  • 水电费进项税额怎么抵扣
  • 辞退福利是指
  • 上月有留抵税额本月怎么申报
  • 小规模没有成本票怎么做账
  • 计提应收的增值税返还
  • 小规模税收优惠政策1%到什么时候
  • 环保税退税优惠政策
  • 资本公积转增股本个人所得税
  • 结存材料应分摊什么
  • 建筑企业劳务费怎么做账
  • 年终零余额账户有余额
  • 交汇算清缴所得吗
  • 厂房面积测绘收费标准
  • 销货清单和发票金额不一致
  • 应收账款已收回但是账面还有余额怎么处理
  • 商品混凝土增值税政策
  • 增值税的税负率的计算公式
  • 期末留抵税额转出怎么报税
  • 公司变卖废纸也需要缴税
  • 破产报表日是哪一日
  • 以前年度的费用可以入在当年吗?
  • 租车费增值税专用发票
  • 个人转让公司限售股纳税地点要求
  • win11系统优化教程
  • php哪个函数能取得字符串长度
  • 资金拆借需防范哪些风险
  • 微信支付宝转账最新规定
  • PHP:session_set_save_handler()的用法_Session函数
  • 折扣销售的定义
  • 处置动产减按2%税率是什么意思
  • 前端静态页面
  • 前端 input
  • 用jsp实现用户登录验证
  • 百度文心一言对未来商业的影响
  • 工业企业采购部工资计入什么科目
  • 怎么查询开具的红字发票
  • 发票章与开票方名称不一致是什么情况
  • 融资租赁的利息进项税可以抵扣吗
  • mybatis执行过程,原理
  • 开具免税的发票,"税率"栏如何填开?
  • mysql索引最大数量
  • 民间非营利组织会计制度及操作实务
  • 短期借款的核算
  • 增值税普通发票查询真伪
  • 房地产企业取得政府补助
  • 营改增后税额计算公式
  • 制造费用月末怎么结转到生产成本
  • 工会经费计提的比例是多少
  • 商会开年会费用怎么入账
  • sql复合语句
  • mac系统10.10
  • freebsd10安装教程
  • win10如何设置快捷键
  • 电脑显示windowsxp不能进入桌面
  • macos high sierra深色模式
  • 开机停在american megatrends
  • 获取windows的最新信息
  • mac怎么找自己下载的应用
  • linux常用命令查看
  • win7开机无法连接所有网络驱动器
  • windows8.1怎么设置密码
  • android打包v1v2
  • Ubuntu修改用户名
  • androidcontext传值
  • unity网络请求
  • jquery 画图
  • jquery22插件网
  • 开票软件提示连接服务器失败怎么办
  • 北京西城税务局
  • 耕地占用税是土地增值税开发成本吗
  • 租房交税是房东交还是中介交
  • 收取广告费收入怎么入账
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设