注意:不是 100% 跨浏览器
检查浏览器兼容性@ http://caniuse.com/#search=FileReader
你会看到人们对不太常见的浏览器有问题,但这可能归结为浏览器的版本。我总是建议使用 caniuse 之类的东西来查看哪一代支持浏览器...这只是用户的工作答案,而不是供人们使用的最终复制和粘贴代码..
小提琴:http://jsfiddle.net/d2atnbrt/3/
HTML 代码:
<input type="file" id="my_file_input" />
<div id='my_file_output'></div>
JS 代码:
var oFileIn;
$(function() {
oFileIn = document.getElementById('my_file_input');
if(oFileIn.addEventListener) {
oFileIn.addEventListener('change', filePicked, false);
}
});
function filePicked(oEvent) {
// Get The File From The Input
var oFile = oEvent.target.files[0];
var sFilename = oFile.name;
// Create A File Reader HTML5
var reader = new FileReader();
// Ready The Event For When A File Gets Selected
reader.onload = function(e) {
var data = e.target.result;
var cfb = XLS.CFB.read(data, {type: 'binary'});
var wb = XLS.parse_xlscfb(cfb);
// Loop Over Each Sheet
wb.SheetNames.forEach(function(sheetName) {
// Obtain The Current Row As CSV
var sCSV = XLS.utils.make_csv(wb.Sheets[sheetName]);
var oJS = XLS.utils.sheet_to_row_object_array(wb.Sheets[sheetName]);
$("#my_file_output").html(sCSV);
console.log(oJS)
});
};
// Tell JS To Start Reading The File.. You could delay this if desired
reader.readAsBinaryString(oFile);
}
这还需要https://cdnjs.cloudflare.com/ajax/libs/xls/0.7.4-a/xls.js 转换为可读格式,我也使用 jquery 仅用于更改 div 内容和 dom 就绪事件.. 所以不需要 jquery
这是我能做到的最基础的,
编辑 - 生成表格
小提琴:http://jsfiddle.net/d2atnbrt/5/
第二个小提琴展示了一个生成你自己的表的例子,这里的关键是使用 sheet_to_json 来获取正确格式的数据以供 JS 使用..
第二个小提琴中的一个或两个 cmets 可能不正确,因为第一个小提琴的修改版本.. CSV 注释至少是
测试 XLS 文件:http://www.whitehouse.gov/sites/default/files/omb/budget/fy2014/assets/receipts.xls
这不包括 XLSX 文件的想法,使用他们的示例进行调整应该相当容易。