gpt4 book ai didi

javascript - 尝试创建 TODO 列表但无法将文本添加到列表中

转载 作者:行者123 更新时间:2023-11-28 03:27:52 25 4
gpt4 key购买 nike

我正在尝试创建一个待办事项列表单击“New TODO”按钮时,屏幕上会出现一个文本字段和提交按钮。但是当我按下提交按钮时,该页面看起来就像初始起始页面。一切都消失了。函数“newTODO()”创建文本框和提交按钮。函数“subitTodo()”删除文本框和提交按钮,并将该文本框中的文本添加到“li”元素。这是代码。

<!DOCTYPE html>
<html>
<head>
<title>TODO App</title>
<link rel="stylesheet" type="text/css" href="./styles.css" />
</head>
<body>
<div class="container center">
<h1 class="center title">My TODO App</h1>
<div class="flow-right controls">
<span>Item count: <span id="item-count">0</span></span>
<span>Unchecked count: <span id="unchecked-count">0</span></span>
</div>
<button class="button center" onClick="newTodo()">New TODO</button>
<ul id="todo-list" class="todo-list"></ul>
</div>
<script src="./script.js"></script>
</body>
</html>

const classNames = {
TODO_ITEM: 'todo-container',
TODO_CHECKBOX: 'todo-checkbox',
TODO_TEXT: 'todo-text',
TODO_DELETE: 'todo-delete',
}

const list = document.getElementById('todo-list')
const itemCountSpan = document.getElementById('item-count')
const uncheckedCountSpan = document.getElementById('unchecked-count')

function newTodo() {
//alert('New TODO button clicked!')
//create a text field and submit button
var newTODO = document.createElement("LI")
newTODO.id = 'newTODOListItem'
list.appendChild(newTODO)

var form = document.createElement("FORM")
//form.innerHTML = "Enter a TODO"
form.id = 'TODOList'
newTODO.appendChild(form)

var x = document.createElement("INPUT")
x.type = 'text'
x.id = 'newTODOText'
x.name = 'name1'
form.appendChild(x)

var y = document.createElement("INPUT")
y.type = 'submit'
y.value = 'Submit'
y.onClick = 'submitTodo(newTODO, form, x.value)'
form.appendChild(y)
}

function submitTodo(newTODO, TODOList, taskText) {
//after submit is clicked
newTODO.removeChild(TODOList)
var myP = document.createElement("P")

newTODO.appendChild(myP)
myP.innerHTML = taskText
}

最佳答案

有很多问题。

  • 该事件是 onclick,而不是 onClick
  • 您输入了按钮类型submit,这正在提交表单
  • 您将处理函数作为字符串传递

我用按钮类型按钮解决了这里的问题。如果您想保留按钮类型提交,则必须在表单提交时阻止默认值。

const classNames = {
TODO_ITEM: 'todo-container',
TODO_CHECKBOX: 'todo-checkbox',
TODO_TEXT: 'todo-text',
TODO_DELETE: 'todo-delete',
}

const list = document.getElementById('todo-list')
const itemCountSpan = document.getElementById('item-count')
const uncheckedCountSpan = document.getElementById('unchecked-count')

function newTodo() {
//alert('New TODO button clicked!')
//create a text field and submit button
var newTODO = document.createElement("LI")
newTODO.id = 'newTODOListItem'
list.appendChild(newTODO)

var form = document.createElement("FORM")
//form.innerHTML = "Enter a TODO"
form.id = 'TODOList'
newTODO.appendChild(form)

var x = document.createElement("INPUT")
x.type = 'text'
x.id = 'newTODOText'
x.name = 'name1'
form.appendChild(x)

function submitHandler() {
submitTodo(newTODO, form, x.value)
}

var y = document.createElement("INPUT")
y.type = 'button'
y.value = 'Submit'
y.onclick = submitHandler;
form.appendChild(y)
}

function submitTodo(newTODO, TODOList, taskText) {
//after submit is clicked
newTODO.removeChild(TODOList)
var myP = document.createElement("P")

newTODO.appendChild(myP)
myP.innerHTML = taskText
}
<ul id="todo-list"></ul>
<p>
Item count: <span id="item-count"></span> Unchecked count: <span id="unchecked-count"></span>
</p>
<button onclick="newTodo()">New todo</button>

关于javascript - 尝试创建 TODO 列表但无法将文本添加到列表中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58462354/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com