我有一个带有jinja
标记的超文本标记语言模板,可以从JSON对象中的列表动态创建标签。创建该内容的循环如下所示。
<div class="card mb-0">
{% for turn in response %}
<div class="card-header collapsed" data-toggle="collapse" data-target="#collapse{{turn['turn_id']}}" href="#">
<a class="card-title"> {{turn['author_name']}} {{turn['date_time']}} </a>
</div>
<div id="collapse{{turn['turn_id']}}" class="card-body collapse in" >
<ul>
{% for sent in turn['list_of_sentences'] %}
<li>{{sent['text']}}</li>
{% for tag in sent['tags'] %}
<label><span class="badge" id="{{tag}}">{{ tag }}</span></label>
{% endfor %}
{% endfor %}
</ul>
</div>
{% endfor %}
</div>
我有一个javascript函数,它根据标签ID更改css类,因为我将标签的textContent分配给了ID。
$(window).on('load', change_label_css );
function change_label_css(){
console.log("Changing CSS classes");
if (document.getElementById("OT").textContent === "OT"){
console.log(document.getElementById("OT").textContent);
document.getElementById("OT").className = "badge badge-warning";
}
if(document.getElementById("RES").textContent === "RES"){
console.log(document.getElementById("RES").textContent);
document.getElementById("RES").className = "badge badge-success";
}
if(document.getElementById("DES").textContent === "DES"){
console.log(document.getElementById("DES").textContent);
document.getElementById("DES").className = "badge badge-light";
}
if(document.getElementById("CW").textContent === "CW"){
console.log(document.getElementById("CW").textContent);
document.getElementById("CW").className = "badge badge-info";
}
if(document.getElementById("Org").textContent === "Org"){
console.log(document.getElementById("Org").textContent);
document.getElementById("Org").className = "badge badge-primary";
}
if(document.getElementById("QT").textContent === "QT"){
console.log(document.getElementById("QT").textContent);
document.getElementById("QT").className = "badge badge-primary";
}
if(document.getElementById("URL").textContent === "URL"){
console.log(document.getElementById("URL").textContent);
document.getElementById("URL").className = "badge badge-secondary";
}
else if(document.getElementById("C").textContent === "C"){
console.log(document.getElementById("C").textContent);
document.getElementById("C").className = "badge badge-dark";
}
console.log("End of changing CSS classes");
}
我不认为这是正确的逻辑,因为我有不同ID和相似ID的标签。
我想就如何旅行通过每个标签和改变基于textContent的CSS类的建议。
转载请注明出处:http://www.syxf119.net/article/20230328/1074921.html