位置: 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年在中国不能用了吗)

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

  • 对外支付哪些项目需要缴税
  • 全国税务师考试准考证打印
  • 租车开发票属于什么类
  • 服务业按什么结算工资
  • 黄金消费税计税依据
  • 预缴所得税更正怎么操作
  • 已经验旧的发票可以作废吗
  • 成品油购进数据未同步怎么办
  • 记账凭证的填写示例
  • 收到办公用品的普票怎么入账
  • 招标代理公司转让
  • 失控发票进项税转出企业无法承担所得税怎么办
  • 公司更名期间账户可以使用吗?
  • 企业支付的工伤赔偿需要什么材料
  • 什么是成本核算你觉得成本核算重要吗为什么
  • 企业征地补偿支出需要什么凭据做账?
  • 多交印花税申请怎么写
  • 私人帐户可以给别人用吗
  • 建筑工程需要哪些部门审批
  • 开具增值税专用发票证明
  • 增值税预缴表填写模板
  • 房产税的常见四大检查点
  • 差额开票扣除额可以大概数
  • 销售货物收入与租金收入的纳税区别
  • 企业出售已使用过的固定资产税率
  • 国外进口的食品还能吃吗
  • 填写报关单需要什么资料
  • windows10更新怎么办
  • 给员工小孩买礼物合适吗
  • 在Win7系统中,文件的属性包括
  • 研发支出怎么做账
  • 负债类科目的分类
  • 小企业会计准则没有以前年度损益调整科目
  • 预计负债属于什么类
  • 商品房缴纳维修基金的规定
  • windows为什么从7开始
  • 限额领料单属于外来原始凭证吗
  • 笔记本显示器分辨率无法调整怎么办
  • 流转税的计税依据有哪些
  • 外国企业如何在阿联酋注册商标
  • 劳务派遣企业简易征收管理办法
  • php分类信息
  • 本地部署gpt4
  • mla指令
  • 手机充值如何开公司发票
  • element级联选择器动态获取数据
  • PostgreSQL分区表(partitioning)应用实例详解
  • 动态sql怎么执行
  • 税务新法规
  • 对公账户怎么查询开户行
  • 发票冲红视频教程
  • 机关单位工会经费的来源
  • 企业法人股权转让要交什么税
  • 税收滞纳金能不能超过税款
  • 钱汇错了报警有用吗
  • 不得从销项税额中抵扣的进项税额,不得计提加计抵减额
  • 汇算清缴后缴纳所得税会计分录
  • 银行存款日记账填写样本图
  • 固定资产二级明细科目有哪些
  • win7旗舰版系统激活码
  • qq8.2.1版本下载正式版
  • window10自带的软件有哪些
  • qtzgacer.exe - qtzgacer进程是什么文件 .作用是什么
  • mac怎么预览cr3
  • windows10x预览版
  • win10更新中重启会怎么样
  • cocos2dx schedule
  • [置顶]bilinovel
  • unity资源管理机制
  • three. js
  • 请问在javascript程序中
  • jqueryui dialog
  • UNITY gameobject代码中setacvtive(false)与面板中直接去掉勾 效果不一样
  • Android 5.1 API 22 所有sdk文件下载地址
  • python操作access数据库
  • 打印格式不对怎么设置A4
  • 沈阳铁西区房产中介电话
  • 山东省地方税务局关于个人所得税
  • 软件企业增值税即征即退政策
  • 税控软件怎么升级到新版本
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设