使用普通JavaScript渲染HTML
我正在客户端消耗API,然后呈现数据,但是,不确定是否有更好的渲染。我做的方式(请参见下面的示例)看起来很混乱且不可读。我不能使用任何框架。这是一个nodejs应用程序。我最初使用的是EJS,但是由于我在客户端上调用API,因此使用EJS是没有意义的。
<script>
let data;
async function getData() {
const response = await fetch(
"/version/all/?format=json&page=11",
{
method: "GET",
mode: "cors",
}
);
let dataresponse = await response.json();
renderData(dataresponse);
}
function renderData(data) {
const div = document.getElementById("main");
const table = document.createElement("table");
table.setAttribute("class", "table");
const tableBody = document.createElement("tbody");
table.appendChild(tableBody);
for (let i = 0; i < data.results.length; i++) {
const th = document.createElement("th");
th.setAttribute("scope", "row");
const chkbox = document.createElement("input");
chkbox.setAttribute("type", "checkbox");
th.append(chkbox)
const tr = document.createElement("tr");
tr.appendChild(th);
tableBody.appendChild(tr);
const td = document.createElement("td");
td.setAttribute("class", "w-40");
const p1 = document.createElement("p");
const a_url = document.createElement("a")
a_url.setAttribute("href", data.results[i].url )
a_url.textContent = `${data.results[i].version.split("-")[0]}`
p1.appendChild(a_url)
td.appendChild(p1);
const p2 = document.createElement("p");
td.appendChild(p2);
p2.appendChild(
document.createTextNode(
`${data.results[i].text.author.author}`
)
);
const p3 = document.createElement("p");
td.appendChild(p3);
p3.appendChild(
document.createTextNode(`${data.results[i].text.title}`)
);
const td2 = document.createElement("td");
td2.setAttribute("class", "w-40");
const p4 = document.createElement("p");
td2.appendChild(p4);
p4.appendChild(
document.createTextNode(`${data.results[i].text.author.author}`)
);
const p5 = document.createElement("p");
td2.appendChild(p5);
p5.appendChild(
document.createTextNode(
`${data.results[i].text.title}`
)
);
const td3 = document.createElement("td");
td3.setAttribute("class", "w-10");
const p6 = document.createElement("p");
sp1 = document.createElement('span')
sp1.setAttribute('class','bi bi-download')
sp2 = document.createElement('span')
sp2.setAttribute('class','bi bi-body-text')
sp3 =document.createElement('span')
sp3.setAttribute('class','bi bi-journal')
sp4 = document.createElement('span')
sp4.setAttribute('class','bi bi-bezier')
p6.appendChild(sp1);
p6.appendChild(sp2);
p6.appendChild(sp3);
p6.appendChild(sp4);
td3.appendChild(p6);
const td4 = document.createElement("td");
td4.setAttribute("class", "w-10");
tr.appendChild(td);
tr.appendChild(td2);
tr.appendChild(td3);
tr.appendChild(td4);
div.appendChild(table);
}
}
getData();
</script>
I am consuming an API on the client-side and then rendering the data, however, not sure if there is a better to render it. The way I have done (see below sample) it seem messy and unreadable. I can't use any framework. This is a nodejs application. I was initially using the ejs but since I am calling the API on the client-side it doesn't make sense to use ejs.
<script>
let data;
async function getData() {
const response = await fetch(
"/version/all/?format=json&page=11",
{
method: "GET",
mode: "cors",
}
);
let dataresponse = await response.json();
renderData(dataresponse);
}
function renderData(data) {
const div = document.getElementById("main");
const table = document.createElement("table");
table.setAttribute("class", "table");
const tableBody = document.createElement("tbody");
table.appendChild(tableBody);
for (let i = 0; i < data.results.length; i++) {
const th = document.createElement("th");
th.setAttribute("scope", "row");
const chkbox = document.createElement("input");
chkbox.setAttribute("type", "checkbox");
th.append(chkbox)
const tr = document.createElement("tr");
tr.appendChild(th);
tableBody.appendChild(tr);
const td = document.createElement("td");
td.setAttribute("class", "w-40");
const p1 = document.createElement("p");
const a_url = document.createElement("a")
a_url.setAttribute("href", data.results[i].url )
a_url.textContent = `${data.results[i].version.split("-")[0]}`
p1.appendChild(a_url)
td.appendChild(p1);
const p2 = document.createElement("p");
td.appendChild(p2);
p2.appendChild(
document.createTextNode(
`${data.results[i].text.author.author}`
)
);
const p3 = document.createElement("p");
td.appendChild(p3);
p3.appendChild(
document.createTextNode(`${data.results[i].text.title}`)
);
const td2 = document.createElement("td");
td2.setAttribute("class", "w-40");
const p4 = document.createElement("p");
td2.appendChild(p4);
p4.appendChild(
document.createTextNode(`${data.results[i].text.author.author}`)
);
const p5 = document.createElement("p");
td2.appendChild(p5);
p5.appendChild(
document.createTextNode(
`${data.results[i].text.title}`
)
);
const td3 = document.createElement("td");
td3.setAttribute("class", "w-10");
const p6 = document.createElement("p");
sp1 = document.createElement('span')
sp1.setAttribute('class','bi bi-download')
sp2 = document.createElement('span')
sp2.setAttribute('class','bi bi-body-text')
sp3 =document.createElement('span')
sp3.setAttribute('class','bi bi-journal')
sp4 = document.createElement('span')
sp4.setAttribute('class','bi bi-bezier')
p6.appendChild(sp1);
p6.appendChild(sp2);
p6.appendChild(sp3);
p6.appendChild(sp4);
td3.appendChild(p6);
const td4 = document.createElement("td");
td4.setAttribute("class", "w-10");
tr.appendChild(td);
tr.appendChild(td2);
tr.appendChild(td3);
tr.appendChild(td4);
div.appendChild(table);
}
}
getData();
</script>
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
它不能在帖子中回答。但是,我喜欢给您一个方法,以了解一种方法。
您可以拥有这样的东西:
希望您明白。
It cannot be answered in a post. But, I like to give you an idea of one way to go about.
You could have something like this:
I hope you get the idea.