【发布时间】:2018-09-22 04:23:51
【问题描述】:
抱歉,这个问题有点混乱。
我想根据单词是什么来改变句子中单词的背景颜色。
我希望用户能够像使用文本区域一样输入单词,但文本区域不支持单词背景颜色。
目前我只能想到这样的超级盗版解决方案:
var div = document.getElementById("div");
function highlight() {
var words = div.textContent.split(" ");
div.innerHTML = "";
for (var i = 0; i < words.length; i++) {
if (words[i] === "good") {
div.innerHTML += "<span style=\"background-color: green;\">" + words[i] + "</span> ";
} else if (words[i] === "bad") {
div.innerHTML += "<span style=\"background-color: red;\">" + words[i] + "</span> ";
} else {
div.innerHTML += "<span>" + words[i] + "</span> ";
}
}
var range = document.createRange();
var sel = window.getSelection();
range.setStart(div.lastChild, 1);
range.collapse(true);
sel.removeAllRanges();
sel.addRange(range);
};
div.addEventListener("input", highlight);
highlight();
div {
background-color: black;
box-sizing: border-box;
color: white;
height: 128px;
padding: 16px;
width: 100%;
}
<div id="div" contenteditable="true">good and bad colors</div>
“好”这个词有绿色背景,“坏”这个词有一个红色背景。
但是,这是非常错误和可怕的,所以我希望有更好的方法来做到这一点。
任何帮助都会非常棒!
【问题讨论】:
标签: javascript html css textarea background-color