JavaScript Todo列表-当我单击“编辑”按钮时,它不显示输入内容以能够更改待办事项

时间:2018-12-22 09:02:49

标签: javascript

作为练习的一部分,我正在使用普通JavaScript构建待办事项列表。我正在尝试使“编辑”选项正常运行。当我单击“编辑”按钮时,应启用并自动选择相应的文本输入,然后用户应该可以按“输入”来提交更改。

问题是我无法使编辑功能正常运行。其他两个按钮运行良好。

我知道已经有一个类似的问题,我已经尝试过该问题中的内容,但仍然无法解决。请帮助大家。

<!DOCTYPE html>
<html>

  <head>
    <link rel="stylesheet" href="style.css">
  </head>

  <body>

    <header>
      <h1>To-do List</h1>
    </header>

      <input type="text" id="addTodoTextInput" onkeyup="todoButtons.addTodo()" placeholder="Add new todo" maxlength="80" autofocus>

    <div>
      <button onclick="todoButtons.toggleAll()">Toggle All</button>
      <button onclick="todoButtons.deleteAll()">Delete All</button>
    </div>

      <ol>
      </ol>

    <script src="script.js"></script>

  </body>

</html>

css

body {
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: #eee; /* Lightblue */
  font-family: tahoma, sans-serif;
}

h1 {
  font-weight: 100;
  color: brown;
}

ol {
  list-style-type: none;
  padding-left: 0;
  min-width: 30%;
}

li {
  padding: 10px;
  border-radius: 8px;
  background-color: white;
  box-shadow: 0 10px 50px black;
  margin-top: 10px;
  transition: all .3s ease;
  overflow: hidden;
}

li:hover {
  box-shadow: 0 10px 50px 3px black;
}

li button {
  float: right;
}

button {
  background-color: #bbb; /* Darkgrey */
  font-weight: bold;
  border-radius: 5px;
  padding: 5px;
  transition: all .3s ease;
  cursor: pointer;
}

button:hover {
  background-color: #d8d2d2; /* Grey */
  color: brown;
}

/* Input for adding new todos */
#addTodoTextInput {
  width: 30%;
  margin-bottom: 20px;
}

js

var todoButtons = {
  todos: [],
  addTodo: function(e) {
    // When Enter is pressed, new todo is made
    if (e.keyCode === 13) {
      var addTodoTextInput = document.getElementById('addTodoTextInput');
      this.todos.push({
      todoText: addTodoTextInput.value,
      completed: false
    });
      // Reseting value after user input
      addTodoTextInput.value = '';
      todoView.displayTodos();
    }
  },
  changeTodo: function(position, newTodoText) {
        this.todos[position].todoText = newTodoText;
        todoView.displayTodos();
    },
  deleteTodo: function(position) {
    this.todos.splice(position, 1);
    todoView.displayTodos();
  },
  toggleCompleted: function (position) {
    var todo = this.todos[position];
    todo.completed = !todo.completed;
    todoView.displayTodos();
  },
  toggleAll: function() {
    var totalTodos = this.todos.length;
    var completedTodos = 0;

    // Checks for a number of completed todos
    this.todos.forEach(function(todo) {
      if (todo.completed === true) {
        completedTodos++;
      }
    });
    this.todos.forEach(function(todo) {
      // If all todos are true, they will be changed to false
      if (completedTodos === totalTodos) {
        todo.completed = false;
      }
      // Otherwise, they will be changed to true
      else {
        todo.completed = true;
      }
    });
    todoView.displayTodos();
  },
  deleteAll: function() {
    this.todos.splice(0, this.todos.length);
    todoView.displayTodos();
  }
};

// Function for displaying todos on the webpage
var todoView = {
  displayTodos: function() {
    var todosUl = document.querySelector('ol');
    todosUl.innerHTML = '';

    // Creating list element for every new todo
    for (var i = 0; i < todoButtons.todos.length; i++) {
      var todoLi = document.createElement('li');
      var todoLiText = document.createElement('input');
      todoLiText.type = "text";
      todoLiText.disabled = true;
      todoLiText.id = 'textInput';
      var todoTextWithCompletion = todoButtons.todos[i].todoText;

      if (todoButtons.todos[i].completed === true) {
        todoLi.style.textDecoration = "line-through";
        todoLi.style.opacity = "0.4";
        todoLi.textContent = todoButtons.todoText + ' ';
      }
      else {
        todoLi.textContent = todoButtons.todoText + ' ';
      }
      todoLi.id = i;
      todoLiText.value = todoTextWithCompletion;
      todoLi.appendChild(this.createDeleteButton());
      todoLi.appendChild(this.createToggleButton());
      todoLi.appendChild(this.createEditButton());
      todoLi.appendChild(todoLiText);
      todosUl.appendChild(todoLi);
    };
  },
  // Method for creating Delete button for each todo
  createDeleteButton: function() {
    var deleteButton = document.createElement('button');
    deleteButton.textContent = 'Delete';
    deleteButton.className = 'deleteButton';
    return deleteButton;
  },
  // Method for creating Toggle button for each todo
  createToggleButton: function() {
    var toggleButton = document.createElement('button');
    toggleButton.textContent = 'Toggle';
    toggleButton.className = 'toggleButton';
    return toggleButton;
  },
  // Method for creating Edit button for each todo
  createEditButton: function() {
    var editButton = document.createElement('button');
    editButton.textContent = 'Edit';
    editButton.className = 'editButton';
    return editButton;
  },
  // Event listeners gor the Delete, Edit and Toggle buttons
  setUpEventListeners: function() {
    var todosUl = document.querySelector('ol');
    todosUl.addEventListener('click', function(event) {
      var position = event.target.parentNode.id;
      var elementClicked = event.target.className;

      if (elementClicked === 'deleteButton') {
        // Path to the ID of each created todo
        todoButtons.deleteTodo(parseInt(position));
      }
    });
    todosUl.addEventListener('click', function(event) {
      var position = event.target.parentNode.id;
      var elementClicked = event.target.className;

      if (elementClicked === 'toggleButton') {
        todoButtons.toggleCompleted(parseInt(position));
      }
    });
    todosUl.addEventListener('click', function(event) {
            var position = event.target.parentNode.id;
      var elementClicked = event.target.className;

            if (elementClicked === 'edit') {
                var input = document.getElementById(position).childNodes[0];

                input.disabled = false;
                input.className = "activeTextInput";
        input.focus();
        input.select();

        input.addEventListener('keyup', function(event) {
                    if(event.keyCode === 13) {
                        var textInput = input.value;
                        input.disabled = true;
                        input.classList.remove("activeTextInput");
                        todoButtons.changeTodo(position, textInput);
                    };
                });
            };
        });
  }
};
// Starting event listeners when the app starts
todoView.setUpEventListeners();

1 个答案:

答案 0 :(得分:0)

所以,我看了看代码。第一个问题是条件:

if (elementClicked === 'edit') {

应为:

if (elementClicked === 'editButton') {

第二个问题是:

if (elementClicked === 'edit') {
                var input = document.getElementById(position).childNodes[0]; //this line

                input.disabled = false;
                input.className = "activeTextInput";

获取正确的元素应该为var input = document.getElementById(position).querySelector('input');

https://jsfiddle.net/nh9j6yw3/1/

“未定义”的原因:
todoLi.textContent = todoButtons.todoText + ' ';行上
todoButtons.todoTextundefined