vue页面中的数据导出excel的方法
第一种方法:该方法比较简单
1、安装插件
cnpm install vue-json-excel
2、在main.js文件中引入插件
import JsonExcel from 'vue-json-excel'
Vue.component('downloadExcel', JsonExcel)
3、在页面中使用
<download-excel
class = "export-excel-wrapper"
:data = "json_data"
:fields = "json_fields"
name = "远程诊断报告导出.xls">
<!-- 上面可以自定义自己的样式,还可以引用其他组件button -->
<el-button type="primary" size="small">导出EXCEL</el-button>
</download-excel>
js中的部分:
data() {
return {
json_fields: {
"头部-诊断名称": "name", //常规字段
"头部-联系电话": "phone.mobile", //支持嵌套属性
"头部-损坏区域代码": {
field: "phone.landline",
//自定义回调函数
callback: value => {
return `损坏区域代码 - ${value}`;
}
}
},
json_data: [
{
name: "损坏的组件一",
city: "New York",
country: "United States",
birthdate: "1978-03-15",
phone: {
mobile: "1-541-754-3010",
landline: "(541) 754-3010"
}
},
{
name: "损坏的组件二",
city: "Athens",
country: "Greece",
birthdate: "1987-11-23",
phone: {
mobile: "+1 855 275 5071",
landline: "(2741) 2621-244"
}
}
],
json_meta: [
[
{
" key ": " charset ",
" value ": " utf- 8 "
}
]
]
};
}
json_data: 需要导出的数据
json_fields: 自主选择要导出的字段,指定嵌套数据并将标签分配给键是标签的字段,值是JSON字段。这将“按原样”导出字段数据。如果需要自定义导出的数据,可以定义回调函数。里面的属性是excel表每一列的title,注意多个词组组成的属性名要加双引号
如果需要自定义导出的数据,可以定义回调函数。
注意:此方法虽然简单,但是不便于控制,不建议使用推荐使用第二种方法。
第二种方法: 该方法比较复杂,但是便于控制。
1、安装三个依赖:
npm install -S file-saver
npm install -S xlsx
npm install -D script-loader
2、项目中新建一个文件夹:(vendor—名字任取)里面放置两个文件Blob.js和 Export2Excel.js。百度可下载。
3、页面中使用