javascript - 如何为div内的每个元素设置边框颜色?
问题描述
我一直在研究标记图像的代码。我能够插入标签,并且为每个插入的标签创建一个小框,标签名将显示在里面。我想做的是,为每个创建的盒子有不同的颜色。
var html = "<div class='inputtag'><i class='fa fa-eye' aria-hidden='true'></i><i class='fa fa-trash-alt' aria-hidden='true'></i><span>" + input + "</span><input type='hidden' name='tag_name[]' value='" + input + "'></div>";
$('.tags').append(html);
var theColors = []
document.querySelectorAll(".inputtag").forEach((el, idx) =>
theColors.push("#" + ((1 << 24) * Math.random() | 0).toString(16)); el.style.borderColor = theColors[idx]
)
.inputtag>i {
margin - right: 4 px;
}
.inputtag {
border - radius: 4 px;
border: 1 px solid skyblue;
color: #000;
padding: 2px 8px;
width: max-content;
text-align: center;
cursor: pointer;
margin: 4px 4px;
float: left;
}
在上面的 Javascript 代码中,我尝试为 div 内的元素获取不同的边框颜色,但在每个新条目后颜色会不断变化。我附上了下面的图片以更好地解释它。
图 1:
在此图像 1 中,您可以看到具有两种不同颜色的元素。当我添加一个新元素时,这些颜色会发生变化。即,对于添加到 Div 中的每个元素,每个元素的边框颜色都会不断变化。
图 2:
图 2 显示了元素边框颜色的变化。我想要的是为 Div 中的每个元素设置不同的固定颜色,这样它们在添加新元素时不会改变颜色。
有人可以帮我解决这个问题。
解决方案
试试这个:
var render = document.querySelector('#tags');
var btnAdd = document.querySelector('#btn-add');
var tags = [];
btnAdd.addEventListener('click', () => {
var nameTag = document.querySelector('#name-tag');
var color = ((1 << 24) * Math.random() | 0).toString(16);
render.innerHTML += `
<div class="tag" style="border-color: #${color};">
${nameTag.value}
</div>
`;
});
.tag {
border-radius: 4px;
border: 2px solid skyblue;
color: #000;
padding: 2px 8px;
margin: 4px 4px;
float: left;
}
<input type="text" id="name-tag" placeholder="name tag...">
<button id="btn-add">Add</button>
<hr>
<div id="tags">
</div>
推荐阅读
- arrays - 使用字符串数组通过 MongoDB 中的嵌入文档查找文档?
- string - 错误消息 - 冲突的 int/float/boolean 和 String 的使用
- email - Flutter 接收邮件
- swagger - 不允许招摇请求正文
- c# - 尽管位置正确,但重定向不起作用 asp.net mvc 错误 404
- kernel - 如何制作加载内核 (.elf) 的可引导光盘 (.iso)
- javascript - 本地存储问题
- php - 使用不可更改的特定地址打开 PayPal 付款
- python - 使用原始索引排序
- algolia - 在 Algolia 中有效检索构面值的所有唯一记录以及记录计数