<script src="https://unpkg.com/xlsx/dist/xlsx.full.min.js"></script>我前端上传的excle表格里面有两个字段一个是name,一个是图片,那么我应该怎么使用xlsx.full.min.js获取,然后展示里面的数据名字和图片在前端呢,怎么使用前端代码实现
时间: 2024-04-15 07:26:40 浏览: 101
通过js获取上传的图片信息(临时保存路径,名称,大小)然后通过ajax传递给后端的方法
要使用`xlsx.full.min.js`库获取Excel表格中的数据并在前端展示名称和图片,您可以按照以下步骤进行操作:
1. 通过`<input type="file">`元素获取用户上传的Excel文件。
2. 使用`FileReader`读取Excel文件的内容,并将其转换为`ArrayBuffer`格式。
3. 使用`XLSX`库解析Excel文件,将其转换为JSON格式。
4. 遍历JSON数据,提取名称和图片字段的值,并在前端展示。
下面是一个示例代码,演示了如何实现上述步骤:
```html
<!DOCTYPE html>
<html>
<head>
<title>Excel Data Display</title>
</head>
<body>
<input type="file" id="excelFile" accept=".xlsx, .xls" />
<div id="dataDisplay"></div>
<script src="https://unpkg.com/xlsx/dist/xlsx.full.min.js"></script>
<script>
function handleFile(e) {
var file = e.target.files[0];
var reader = new FileReader();
reader.onload = function (e) {
var data = new Uint8Array(e.target.result);
var workbook = XLSX.read(data, { type: "array" });
// 获取Excel第一个sheet的内容
var worksheet = workbook.Sheets[workbook.SheetNames[0]];
// 将Excel数据解析为JSON格式
var jsonData = XLSX.utils.sheet_to_json(worksheet, { header: 1 });
// 显示数据
var dataDisplay = document.getElementById("dataDisplay");
for (var i = 0; i < jsonData.length; i++) {
var name = jsonData[i].name;
var image = jsonData[i].image;
// 创建显示名称的元素
var nameElement = document.createElement("p");
nameElement.innerHTML = "Name: " + name;
dataDisplay.appendChild(nameElement);
// 创建显示图片的元素
var imageElement = document.createElement("img");
imageElement.src = image;
dataDisplay.appendChild(imageElement);
}
};
reader.readAsArrayBuffer(file);
}
// 监听文件上传事件
document.getElementById("excelFile").addEventListener("change", handleFile, false);
</script>
</body>
</html>
```
在这个示例中,我们假设Excel文件中的JSON数据格式如下:
```json
[
{ "name": "John", "image": "path/to/image1.jpg" },
{ "name": "Jane", "image": "path/to/image2.jpg" },
...
]
```
在页面上,我们使用`<input type="file">`元素获取用户上传的文件,并在`handleFile`函数中使用`XLSX`库解析Excel文件。然后,我们遍历JSON数据,提取每个对象中的名称和图片字段的值,并使用DOM操作在页面上展示。
请根据您的具体需求和数据结构进行适当的修改和优化。
阅读全文