js-xlsx前端读取Excel(导入)兼容IE和其他浏览器

本文介绍了一种使用js-xlsx在前端读取Excel文件的方法,并将其数据展示在网页的table中,特别针对IE浏览器的支持问题进行了处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 网上看了很多前端导入Excel的文章,都不支持IE,所以打算记录一下。

使用js-xlsx前端读取Excel文件,把读取的表格数据放到页面的table中。例子如下

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
   <title>读取Excel</title>	
   <script src="jquery-2.2.0.js"></script>
   <script src="xlsx.core.min.js"></script>
</head>
<body>
<br/>
<label for="excel-file" class="btn btn-success">导入Excel文件</label>
<input type="file" name="excel-file" id="excel-file"/>
<br>
<table id="context">

</table>

  <script>  
	$('#excel-file').change(function(e) {            
	        try {
	            new Uint8Array([1,2]).slice(0,2);
	        } catch (e) {
	            console.log("[Uint8Array"+e.description+"]这里使用【Array.slice】。");
	            //IE或有些浏览器不支持Uint8Array.slice()方法。改成使用Array.slice()方法
	            Uint8Array.prototype.slice = Array.prototype.slice;
	        }
	        var url=$('#excel-file').val();
	        if(!url){return;}
	        var suffix=url.substring(url.lastIndexOf(".")+1,url.length);
	        if(!(suffix=="xls"||suffix=="xlsx")){
	            return alert("文件类型不正确");
	        }
	        var files = e.target.files;	        
	        var fileReader = new FileReader();
	        fileReader.readAsArrayBuffer(files[0]);// 以二进制方式打开文件
	        fileReader.onload = function(ev) {
	            $('#excel-file').val('');
	            $("#context").html("");
	            try {	                
	            	var data = ev.target.result;
	            	var workbook = XLSX.read(data, { type: 'array'}),
	                persons = [];
	            } catch (e) {
	            	console.error(e);
	                return alert('文件类型不正确!');
	            }
	            
	            //遍历每张表读取
	            for (var sheet in workbook.Sheets) {
	                if (workbook.Sheets.hasOwnProperty(sheet)) {
	                    persons = persons.concat(XLSX.utils.sheet_to_json(workbook.Sheets[sheet],{raw:true, header:1}));
	                    
	                    for ( var i = 0; i <persons.length; i++){
	                        var person=persons[i];
	                        var tr='<tr id="tr-'+i+'">';
	                        for (var j = 0; j <person.length; j++){
	                            tr+='<td>'+$.trim(person[j]?person[j]:"")+'</td>';
	                        }
	                        for (var k = 0; k < (6-person.length); k++) {
	                        	tr+='<td></td>';
							}
	                        if(person.length>1){
	                            tr+='<td style="padding:6px;"><a href="javascript:$(\'#tr-'+i+'\').remove();" class="btn btn-danger btn-xs">删除</a></td></tr>';
	                            $("#context").append(tr);
	                        }
	                    }
	                    break;// 如果只取第一张表,就把beak注释取消
	                }
	            }
	        };
	    });

  </script>
</body>
</html>

 

评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值