![](/img/trans.png)
[英]Knockout - Give class to one <li> element in a foreach <ul> with <li> elements
[英]how to select or give a class name to createTextNode() tekst inside Li elements
我做了一个购物清单,现在我想点击它时删除这些物品。 当我现在单击它时,整个 li 项目被删除(标记和deletebutton
按钮现在被删除)。 我想给我在这个脚本中创建的列表项中的 tekst 一个 class,但我无法让它工作。 这是制作列表项的脚本:
function createListElement() {
var li = document.createElement("li");
li.appendChild(document.createTextNode(input.value));
li.classList.add("tekstje");
ol.appendChild(li);
input.value = "";
var delBtn = document.createElement("BUTTON"); // Create a <button> element
delBtn.classList.add("deletebtn"); // Give a class name
delBtn.innerHTML = "X"; // Insert text
li.appendChild(delBtn); // Append <button> to <LI>
}
我尝试了classlist.add
方法并给它一个 P class,但这似乎不起作用。 我还尝试使用:tekst 选择它
覆盖内部按钮上的 CSS。 或者,只需用 span 将文本包装在li
中,然后只在span
上添加删除线。
var ol = document.getElementById("theOl"); var input = document.getElementById("theInput"); function createListElement() { var li = document.createElement("li"); li.appendChild(document.createTextNode(input.value)); li.classList.add("tekstje"); ol.appendChild(li); input.value = ""; var delBtn = document.createElement("BUTTON"); // Create a <button> element delBtn.classList.add("deletebtn"); // Give a class name delBtn.innerHTML = "X"; // Insert text delBtn.onclick = function () { delBtn.parentNode.classList.add("all-done"); } li.appendChild(delBtn); // Append <button> to <LI> }
.all-done { text-decoration: line-through; }.all-done button { text-decoration: none; }
<ol id="theOl"></ol> <input id="theInput" value="test"> <button onclick="createListElement()">Add</button>
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.