Maison > Questions et réponses > le corps du texte
Lorsque je souhaite ajouter une étiquette à un mot dans la zone de texte, l'étiquette n'est pas acceptée. Existe-t-il un moyen d'étiqueter du texte dans une zone de texte en cliquant sur le mot que je souhaite étiqueter ? Par exemple la balise span
<label> <textarea class="string-example" name="textarea3" id="textarea3" cols="122" rows="17">Lorem ipsum dolor sit amet...</textarea> </label>
P粉7878203962023-09-11 10:39:22
Double-cliquez sur le texte dans la zone de texte et le texte sera mis en surbrillance. Si vous voulez juste styliser, utilisez CSS : ::selection
textarea::selection { color: white; background-color: black; }
<textarea>Lorem ipsum dolor sit amet, consectetur adipisicing elit ipsum. Eaque, facere architecto. Ipsum quas, modi impedit veritatis earum sunt quo reiciendis. Hic, sapiente earum fuga accusamus qui eos itaque provident! Eaque, ipsum in.</textarea>
Soit utilisez Ce qui précède est une preuve de concept, vous aurez toujours besoin de JavaScript pour cloner le texte dans Je laisse la sélection des clics au lecteur.
ou
Utilisez Textarea comme superposition DIV - le balisage sera mis en surbrillance
.markable {
display: inline-block;
position: relative;
}
.markable>* {
all: unset;
outline: 1px solid #999;
vertical-align: top;
font: 16px/1.4 monospace;
}
.markable div {
position: absolute;
top: 0;
left: 0;
height: 100%;
width: 100%;
color: transparent;
}
.markable textarea {
position: relative;
}
<div class="markable">
<div>Lorem <mark>ipsum</mark> dolor sit amet...</div>
<textarea>Lorem ipsum dolor sit amet...</textarea>
</div>
.highliter
DIV 中,插入 元素子元素围绕所需的文本
选择
- et assurez-vous (si nécessaire) que le DIV sous-jacent défile de manière synchronisée avec la zone de texte. const search = "ipsum";
const regEsc = (str) => str.replace(/[/\-\^$*+?.()|[\]{}]/g, '\$&');
const markable = (elMarkable) => {
const elDiv = elMarkable.querySelector("div");
const elTxt = elMarkable.querySelector("textarea");
const updateScroll = () => {
elDiv.scrollTop = elTxt.scrollTop;
};
const updateMark = () => {
const val = elTxt.value;
const markedVal = val.replace(new RegExp(`\b${regEsc(search)}\b`, "gi"), `<mark>$&</mark>`);
elDiv.setHTML(markedVal);
};
elTxt.addEventListener("scroll", updateScroll);
elTxt.addEventListener("input", updateScroll);
elTxt.addEventListener("input", updateMark);
// Init:
updateScroll();
updateMark();
};
document.querySelectorAll(".markable").forEach(markable);
.markable {
display: inline-block;
position: relative;
}
.markable>* {
all: unset;
outline: 1px solid #999;
vertical-align: top;
font: 16px/1.4 monospace;
}
.markable div {
position: absolute;
top: 0;
left: 0;
height: 100%;
width: 100%;
color: transparent;
overflow: auto;
}
.markable textarea {
position: relative;
}
<p>Edit the text in textarea below. The string to be highlighted is "ipsum" (case insensitive)</p>
<div class="markable">
<div></div>
<textarea name="textarea3" cols="40" rows="2">Lorem ipsum dolor sit amet, consectetur adipisicing elit ipsum. Eaque, facere architecto. Ipsum quas, modi impedit veritatis earum sunt quo reiciendis. Hic, sapiente earum fuga accusamus qui eos itaque provident! Eaque, ipsum in.</textarea>
</div>