
本文将介绍如何使用 JavaScript 动态地在 HTML 中渲染对象属性,并根据属性值是否存在来决定是否显示它们。我们将探讨一种更简洁的方法,避免冗余的代码,提高代码的可维护性和可读性。通过使用对象键值对和数组方法,可以有效地处理条件渲染的需求。
在Web开发中,经常需要根据数据动态生成HTML内容。当数据对象包含可选属性时,我们可能希望只显示那些存在的属性。下面我们将介绍一种更简洁的方法来实现这一目标。
假设我们有一个包含方向信息的对象:
let dirs = { nord: 10, est: 19, sudouest: 5 };我们希望将这些方向信息以“标签: 值”的形式显示在HTML中,但只显示那些值不为null或undefined的属性。
立即学习“Java免费学习笔记(深入)”;
避免使用大量的条件判断和重复的代码,我们可以利用JavaScript的对象和数组方法来简化实现。
首先,创建一个翻译对象,将属性名映射到更友好的显示名称:
const translations = {
nord: 'Nord',
sud: 'Sud',
ouest: 'Ouest',
est: 'Est',
sudouest: 'Sud-ouest',
sudest: 'Sud-est',
nordouest: 'Nord-ouest',
nordest: 'Nord-est'
}然后,使用Object.entries()方法将对象转换为键值对数组,并使用map()方法遍历该数组,为每个键值对生成HTML字符串。
function print_directions(dirs) {
const translations = {
nord: 'Nord',
sud: 'Sud',
ouest: 'Ouest',
est: 'Est',
sudouest: 'Sud-ouest',
sudest: 'Sud-est',
nordouest: 'Nord-ouest',
nordest: 'Nord-est'
}
const html = Object.entries(dirs)
.map(([dir, value]) =>
`<div class="info-dir">
${translations[dir] || dir}:
<span>${value}</span>
</div>`
)
.join('');
document.querySelector(".content").innerHTML = html;
}
let dirs = { nord: 10, est: 19, sudouest: 5 };
print_directions(dirs);在这个代码中:
完整的示例代码如下:
<!DOCTYPE html>
<html>
<head>
<title>Conditional Rendering</title>
<style>
.d-none {
display: none;
}
</style>
</head>
<body>
<div class="content"></div>
<script>
function print_directions(dirs) {
const translations = {
nord: 'Nord',
sud: 'Sud',
ouest: 'Ouest',
est: 'Est',
sudouest: 'Sud-ouest',
sudest: 'Sud-est',
nordouest: 'Nord-ouest',
nordest: 'Nord-est'
}
const html = Object.entries(dirs)
.map(([dir, value]) =>
`<div class="info-dir">
${translations[dir] || dir}:
<span>${value}</span>
</div>`
)
.join('');
document.querySelector(".content").innerHTML = html;
}
let dirs = { nord: 10, est: 19, sudouest: 5 };
print_directions(dirs);
</script>
</body>
</html>通过使用对象键值对和数组方法,我们可以更简洁地实现条件渲染的需求,避免冗余的代码,提高代码的可维护性和可读性。这种方法适用于各种需要根据数据动态生成HTML内容的场景。
以上就是使用 JavaScript 有条件地在 HTML 中渲染数据的详细内容,更多请关注php中文网其它相关文章!
HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号