首先,这里需要实现的效果为:

当点击<el-button>按钮时,打开文件夹,选择excel表并上传,读取excel表中的内容,并把内容填写至<el-table>之中,如图:

 

接下来需要做的是安装3个依赖和添加两个js文件:

npm install -S file-saver xlsx(这里其实安装了2个依赖)
 
npm install -D script-loader

好了,三个依赖安装好了(记得要在main.js文件中引用,不会的同学自行百度)
接着在src中建个文件夹,文件夹名字随意,在文件夹中放入这两个文件:

两个JS文件

接下来,代码部分

<el-upload
            class="upload-demo"
            action=""
            :on-change="handleChange"
            :show-file-list="false"
            :on-remove="handleRemove"
            accept="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet,application/vnd.ms-excel"
            :auto-upload="false">
            <el-button size="small" type="primary" >点击上传</el-button>
            <div slot="tip" class="el-upload__tip">注:只 能 上 传 xlsx / xls 文 件</div>
        </el-upload>

	// excel表上传
	handleChange(file, fileList) {
		this.fileTemp = file.raw
		// 判断上传文件格式
		if (this.fileTemp) {
			if ((this.fileTemp.type == 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet') || (this.fileTemp.type ==
					'application/vnd.ms-excel')) {
					this.importfxx(this.fileTemp)
			} else {
				this.$message({
					type: 'warning',
					message: '附件格式错误,请删除后重新上传!'
				})
			}
		} else {
			this.$message({
				type: 'warning',
				message: '请上传附件!'
			})
		}
	},
	// 移除excel表
	handleRemove(file, fileList) {
		this.fileTemp = null
	},
	importfxx(obj) {
		let _this = this;
		// 通过DOM取文件数据
		this.file = obj
		var rABS = false; //是否将文件读取为二进制字符串
		var f = this.file;
		var reader = new FileReader();
		FileReader.prototype.readAsBinaryString = function(f) {
			var binary = "";
			var rABS = false; //是否将文件读取为二进制字符串
			var pt = this;
			var wb; //读取完成的数据
			var outdata;
			var reader = new FileReader();
			reader.onload = function(e) {
				var bytes = new Uint8Array(reader.result);
				console.log(reader.result)
				var length = bytes.byteLength;
				for (var i = 0; i < length; i++) {
					binary += String.fromCharCode(bytes[i]);
				}
				var XLSX = require('xlsx');
				if (rABS) {
					wb = XLSX.read(btoa(fixdata(binary)), { //手动转化
						type: 'base64'
					});
				} else {
					wb = XLSX.read(binary, {
						type: 'binary'
					});
				}
				outdata = XLSX.utils.sheet_to_json(wb.Sheets[wb.SheetNames[0]]); //outdata就是读取excel内容之后输出的东西
				this.da = [...outdata]

				//return arr
				// 把读取的excel表格中的内容放进tableData2中(这里要改成自己的表的名字)
				_this.tableData2 = _this.tableData2.concat(this.da)
			}
			reader.readAsArrayBuffer(f);

		}
		if (rABS) {
			reader.readAsArrayBuffer(f);
		} else {
			reader.readAsBinaryString(f);
		}
	},
Logo

前往低代码交流专区

更多推荐