点击重新打开一个页面窗口,不覆盖当前的页面
window.open('https://www.baidu.com',"_blank")"_blank" 新打开一个窗口"_self" 覆盖当前的窗口
例如:导入用户模板下载
templateDownload() {window.open('https:网址', "_self")
},
let arrayNew = [];
datas.map((item, index) => {arryNew.push(Object.assign({}, item, {name: item.myName,value:item}));return arrayNew;
});
this.List = arrayNew;
在第三个问题的代码上进行添加:
data() {return {props: {value: "Code",label: "Name",checkStrictly:true //关键代码:设置父子节点取消选中关联,可以选择任意一级选项},}}
const tel = '15611116666' //获取到接口返回的手机号
this.userTel= tel.replace(/(\d{3})\d{4}(\d{4})/, '$1****$2');
通过vue实现导出有2种方式:
(1)后端返回的是一个地址,直接拼接打开下载即可。
(2)后端返回的是文件流的形式,这个时候就需要在 请求头和返回值 这两处设置一下。
// 页面代码
导出exportFun() { //导出方法ExpUserList(this.listQuery) //导出接口.then(result => {const url = result.datawindow.open(url) //通过这个打开网页就可下载导出}).catch(err => console.log(err))}
1)设置请求头
// 导出用户数据查询(封装的接口)
export function ExpUserList(StartDate, EndDate, DistrictCode, IsNormal, Age) {return request({url: 'admin/Export/ExpUserList.ashx' + '?token=' + getToken() + '&StartDate=' + StartDate +'&EndDate=' + EndDate + '&DistrictCode=' + DistrictCode + '&IsNormal=' + IsNormal + '&Age=' + Age,method: 'Get',responseType: 'blob' //指明返回格式( 需要在此处设置请求头,设置请求的类型为blob文件流的形式)})
}
2)设置返回结果,处理返回的文件流
// 页面代码
导出//调用导出接口
exportFun() {ExpUserList(this.listQuery.StartDate, this.listQuery.EndDate, this.listQuery.DistrictCode, this.listQuery.IsNormal, this.listQuery.Age).then(res => {console.log(res)this.exportName = `用户数据` //导出的文件名称let href = window.URL.createObjectURL(new Blob([res])); //将文件流转化为blob地址let link = document.createElement('a'); //创建a标签link.style.display = 'none';// 设置连接link.href = href;link.setAttribute('download', this.exportName + '.xlsx');document.body.appendChild(link);//设置点击事件link.click();document.body.removeChild(link); // 下载完成移除元素window.URL.revokeObjectURL(href); // 释放掉blob对象}).catch(err => {console.log(err)})
},
3)小提示:
有的时候做到上述几步还是不能导出,debugger 之后,发现接口调用的时候直接走的.catch,没走.then,
所以需要我们在全局响应拦截做一些判断。
//一般在utils下面的requext.js文件里面
export function validResponse(res, errorMessage) {if (res instanceof Blob) { //如果返回的是文件流的形式,直接return resreturn res} else if (res.code !== 200 && res.code !== 201 && res.code !== 204) {return Promise.reject(new Error(res.message || '发生错误!'))} else {return res}
}
是 否
export default {data() {return {myRadio: false, //布尔值};}
};
是 否 不清楚
export default {data() {return {myRadio: 1, //这里改为数字};}
};
是 否
上一篇:UDP协议
下一篇:电子采购一体化解决方案