vue 如何打开接口返回的HTML文件

前言:接口测试平台,后端使用django,前端使用vue+element。项目接口平台测试完成,需要把后台产生的测试报告返回给前端展示。

一、后端接口

    1、配置下django的template的参数,templates文件夹是放在project的目录下面的,是项目中或者说项目中所有的应用公用的一些模板

 

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [os.path.join(BASE_DIR, 'userfiles')],
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
        },
    },
]

2、视图函数,读取template目录下report文件夹的报告,并返回给前端

 def getReport(self, request):
        # 获取POST BODY信息
        reportId = request.data["id"]
        try:
            print(os.getcwd()) # 打印程序运行目录
            template = loader.get_template(f"./report/{reportId}.html")
            # template = loader.get_template(f"1.html")
            return Response(template.render())
            # return HttpResponse(template.render())
        except Exception as e:
            content = {'message': '获取报告失败'}
            return Response(content)

二、前端

1、如果后端返回的HTML文件不包含js文件,可以使用vue的v-html,vue的v-html只能渲染html元素和css文件,,不能执行js文件

 

2、后端返回的数据,HTML文件包含js文件。使用下面这种方法,接口获取到的html数据在暂存的本地localStorage,再读取数据,然后在新窗口打开报告。

接口返回的数据如下:

 template:

 <el-button type="warning" @click="viewReport" :disabled="reportDisabled
"

methods:


 // 查看测试报告
  viewReport () {
    var message = {id:1}
    //  axios 通过接口获取后台的报html告文件数据
    getReport(message).then(res => {
      this.$message({
        showClose: true,
        message: res.data.message,
        type: 'success'
      })
      // res.data 为接口返回的html完整文件代码
       // 必须要存进localstorage,否则会报错,显示不完全
      window.localStorage.removeItem('callbackHTML')
      window.localStorage.setItem('callbackHTML', res.data)
    // 读取本地保存的html数据,使用新窗口打开
      var newWin = window.open('', '_blank')
      newWin.document.write(localStorage.getItem('callbackHTML'))
      // 关闭输出流
      newWin.document.close()
    }).catch(err => {
      this.$message({
        showClose: true,
        message: err.response.msg,
        type: 'error'
      })
    })
  }

至此结束,点击下按钮即可在新窗口展示测试报告了

  • 5
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: Vue接口返回的二维码流文件是一个二进制数据,在前端中可以通过将流文件转换为Base64编码的字符串来进行处理和展示。可以使用Axios等HTTP请求库发送请求获取二维码流文件,然后将其转换为Base64编码。 首先,在Vue组件中引入Axios库,并发送GET请求获取二维码流文件: ```javascript import axios from 'axios'; axios({ method: 'GET', url: '/api/qrcode', responseType: 'blob' // 设置响应类型为二进制数据流 }).then(response => { const blob = response.data; const reader = new FileReader(); reader.readAsDataURL(blob); // 将二进制数据流转换为Base64编码 reader.onloadend = () => { const base64Data = reader.result; this.qrcodeImage = base64Data; // 将Base64编码的二维码图片赋给组件的数据属性 }; }); ``` 然后,在Vue模板中使用`img`标签来展示Base64编码的二维码图片: ```html <template> <div> <img :src="qrcodeImage" alt="二维码"> </div> </template> ``` 最后,在Vue组件的数据属性中定义`qrcodeImage`用于存储Base64编码的二维码图片: ```javascript export default { data() { return { qrcodeImage: '' }; } } ``` 这样,通过将二维码流文件转换为Base64编码的字符串,我们可以在Vue中展示接口返回的二维码图片。 ### 回答2: Vue 接口返回的二维码流文件,可以通过以下步骤进行处理: 首先,在 Vue 组件中发起请求获取二维码流文件。可以使用 Axios 这样的库来发送 HTTP 请求,并设置响应类型为二进制流。 ```javascript axios({ method: 'GET', url: 'your_api_endpoint', responseType: 'blob' // 设置响应类型为二进制流 }).then(response => { // 处理返回的二维码流文件 const qrCodeBlob = response.data; // ... }).catch(error => { // 处理请求错误 console.error(error); }); ``` 接下来,对返回的二维码流文件进行处理。可以使用 FileSaver.js 这样的库将二进制流保存为二维码图片文件。 ```javascript import { saveAs } from 'file-saver'; // 保存二维码流文件为图片文件 saveAs(qrCodeBlob, 'qrcode.png'); ``` 这样就成功将接口返回的二维码流文件保存为本地的图片文件了。 请注意,以上代码中的 `your_api_endpoint` 是你实际的接口地址,需要替换为正确的值。另外,需要在 Vue 项目中安装并导入 Axios 和 FileSaver.js 这两个库。 希望以上回答能对你有所帮助,如果还有其他疑问,请随时追问。 ### 回答3: 当Vue接收到接口返回的二维码流文件时,可以通过以下方式进行处理: 1. 接口返回的二维码流文件可以是一个二进制流,我们可以使用Vue中的axios库来发送请求获取该接口返回文件流数据。 2. 在Vue组件中,通过axios发送请求获取接口返回的二维码流文件。可以使用axios的get方法来发送请求,并将接口地址作为参数传递进去。 3. 在获取到文件流数据后,可以将其转换成Blob对象,可以使用FileReader对象来进行转换。 4. 使用FileReader的readAsDataURL方法将Blob对象转换为data URL,这样可以在前端页面中直接显示这个二维码图片。 5. 将转换后的data URL赋值给Vue组件中的图片对象的src属性,即可在页面上显示二维码图片。 以上是处理Vue接收到接口返回的二维码流文件的一般流程,具体的实现可能需要根据实际情况进行调整和完善。这样,我们就可以在Vue中成功处理接口返回的二维码流文件,并在页面上显示二维码图片。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值