Ajax獲取本地excel文件,將excel文件數據轉換為json,js獲取轉換后的json中的數據,將數據顯示在html中
时间: 2024-03-30 15:36:55 浏览: 68
可以通过以下方式实现:
1. 发送Ajax请求获取本地excel文件,并将excel文件数据转换为json格式
```javascript
var xhr = new XMLHttpRequest();
xhr.open('GET', 'path/to/excel/file.xlsx', true);
xhr.responseType = 'arraybuffer';
xhr.onload = function(e) {
if (xhr.status == 200) {
var data = new Uint8Array(xhr.response);
var workbook = XLSX.read(data, {type: 'array'});
// 将workbook转换为json格式
var jsonData = {};
workbook.SheetNames.forEach(function(sheetName) {
var sheet = workbook.Sheets[sheetName];
jsonData[sheetName] = XLSX.utils.sheet_to_json(sheet);
});
// 处理json数据
processData(jsonData);
} else {
console.error('Failed to load excel file');
}
};
xhr.send();
```
2. 处理json数据,并将数据显示在HTML页面中
```javascript
function processData(jsonData) {
// 选择要显示数据的DOM元素
var tableBody = document.querySelector('#table-body');
// 遍历json数据,将数据添加到HTML表格中
for (var sheetName in jsonData) {
var sheetData = jsonData[sheetName];
// 创建表格行
var row = document.createElement('tr');
// 创建表格单元格,并添加到行中
var sheetNameCell = document.createElement('td');
sheetNameCell.textContent = sheetName;
row.appendChild(sheetNameCell);
sheetData.forEach(function(data) {
var dataCell = document.createElement('td');
dataCell.textContent = data.columnName; // 根据实际数据列名获取数据
row.appendChild(dataCell);
});
// 将行添加到表格中
tableBody.appendChild(row);
}
}
```
3. 在HTML页面中添加用于显示数据的表格
```html
<table>
<thead>
<tr>
<th>Sheet Name</th>
<th>Column 1</th>
<th>Column 2</th>
<!-- 添加其他列 -->
</tr>
</thead>
<tbody id="table-body">
</tbody>
</table>
```
阅读全文