Ajax (Asynchronous JavaScript and XML) 是一种在不重新加载整个页面的情况下,与服务器交换数据并更新部分网页的技术。通过Ajax请求数据后使用JavaScript动态填充表格是现代Web开发中的常见模式。
// 创建XMLHttpRequest对象
var xhr = new XMLHttpRequest();
// 配置请求
xhr.open('GET', 'api/data', true);
// 设置回调函数
xhr.onload = function() {
if (xhr.status === 200) {
var data = JSON.parse(xhr.responseText);
populateTable(data);
} else {
console.error('请求失败: ' + xhr.status);
}
};
// 发送请求
xhr.send();
// 填充表格函数
function populateTable(data) {
var table = document.getElementById('dataTable');
var tbody = table.querySelector('tbody') || table.createTBody();
tbody.innerHTML = ''; // 清空现有内容
data.forEach(function(item) {
var row = tbody.insertRow();
Object.keys(item).forEach(function(key) {
var cell = row.insertCell();
cell.textContent = item[key];
});
});
}
$.ajax({
url: 'api/data',
method: 'GET',
dataType: 'json',
success: function(data) {
var tableBody = $('#dataTable tbody');
tableBody.empty();
$.each(data, function(index, item) {
var row = $('<tr>');
$.each(item, function(key, value) {
row.append($('<td>').text(value));
});
tableBody.append(row);
});
},
error: function(xhr, status, error) {
console.error('请求失败: ' + error);
}
});
fetch('api/data')
.then(response => {
if (!response.ok) {
throw new Error('网络响应不正常');
}
return response.json();
})
.then(data => {
const tableBody = document.querySelector('#dataTable tbody');
tableBody.innerHTML = '';
data.forEach(item => {
const row = document.createElement('tr');
Object.values(item).forEach(value => {
const cell = document.createElement('td');
cell.textContent = value;
row.appendChild(cell);
});
tableBody.appendChild(row);
});
})
.catch(error => {
console.error('请求失败:', error);
});
现象:浏览器控制台报跨域错误
原因:浏览器同源策略限制
解决方案:
现象:请求成功但表格未更新
原因:
解决方案:
现象:大数据量时页面卡顿
原因:一次性渲染过多DOM元素
解决方案:
通过合理使用Ajax和JavaScript动态填充表格,可以创建高效、响应式的Web应用程序,提供良好的用户体验。