为什么要写出 console.log?

时间:2021-04-12 19:35:19

标签: javascript addeventlistener timing updating

我有以下内容,想知道 taskInput 是如何更新的。

我在我的 js 顶部抓取 taskInput。然后我在“提交”表单中添加了一个监听器。因此,当我通过单击添加任务提交表单时,为什么我不必再次抓取 taskInput 以查看它的新值?

const taskInput = document.getElementById('task');
const form = document.querySelector('form');
const filter = document.querySelector('input[name="filter"]');
const taskList = document.querySelector('ul.collection');
const clearall = document.querySelector('.clear-tasks');

loadAllEventListeners()

function loadAllEventListeners(){

  form.addEventListener('submit',submit)

}

function submit(e){
  e.preventDefault();
  console.log(taskInput.value)
}
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/materialize/0.100.2/css/materialize.min.css">
  <link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet" integrity="sha384-wvfXpqpZZVQGK6TAh5PVlGOfQNHSoD2xbE+QkPxCAFlNEevoEH3Sl0sibVcOQVnN" crossorigin="anonymous">
  <title>Task List</title>
</head>
<body>
  <div class="container">
    <div class="row">
      <div class="col s12">
        <div id="main" class="card">
          <div class="card-content">
            <span class="card-title">Task List 1</span>
            <div class="row">
              <form id="task-form">
                <div class="input-field col s12">
                  <input type="text" name="task" id="task">
                  <label for="task">New Task </label>
                </div>
                <input type="submit" value="Add Task" class="btn">
              </form>
            </div>
          </div>
          <div class="card-action">
            <h5 id="task-title">Tasks</h5>
            <div class="input-field col s12">
              <input type="text" name="filter" id="filter">
              <label for="filter">Filter Tasks</label>
            </div>
            <ul class="collection"></ul>
            <a href="#" class="clear-tasks btn black">Clear Tasks</a>
          </div>
        </div>
      </div>
    </div>
  </div>

  <script
  src="https://code.jquery.com/jquery-3.2.1.js"
  integrity="sha256-DZAnKJ/6XZ9si04Hgrsxu/8s717jcIzLy3oi35EouyE="
  crossorigin="anonymous"></script>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/materialize/0.100.2/js/materialize.min.js"></script>
</body>
</html>

2 个答案:

答案 0 :(得分:2)

如果我对您的问题理解有误,我们深表歉意。但是你问为什么不用手动更新js中taskInput(输入框)的值?

意思是为什么每次都自动获取输入的新值?

如果这就是你要问的,那是因为当你写作

const taskInput = document.getElementById('task');

它实际上是获取对表示输入字段的 Element 对象的引用,而不是实际的 .value 属性。

所以 taskInput 只是指向输入元素对象,当输入元素对象更新时,作为元素引用的变量也会显示更新后的值。

类似于这个 -

const obj = {
  value: 2
};
const reference = obj;
console.log(reference) // will output { value: 2 }
obj.value = 5;
console.log(reference) // will output { value: 5 }

所以我们从未直接接触过 reference 变量,我们只更新了 obj 但由于 reference 只是指向 obj(它是一个对象)它也反映了更新的值

查看这些链接以进一步阅读:

  1. JavaScript by reference vs. by value
  2. https://codeburst.io/explaining-value-vs-reference-in-javascript-647a975e12a0

答案 1 :(得分:0)

您不是从输入字段值创建常量,而是从带有 id="task" 本身的输入 DOM 元素创建常量。 DOM 元素是具有可随时间变化的属性的对象。 const 赋值引用了这个 DOM 元素的确切实例。通过对对象进行 const 赋值,您无法更改对新对象的引用,但对象中的每个值仍然是可变的。

相关问题