如何重新实现 JavaScript 的 delete 方法?


JavaScript 中的 delete 运算符用于从对象中删除属性,从数组中删除元素或从集合对象中删除元素。始终记住以下关于 delete 的要点:delete 是 JavaScript 中的关键字,因此不应更改它,并且不能在单个变量中使用 delete 对象,因为它仅用于删除对象的属性。

让我们详细了解如何在 JavaScript 中实现 delete 运算符。

删除对象属性

JavaScript 中的对象,我们将使用键值对编写,例如

const Employee = {
   firstname: 'Devika',
   lastname: 'Rani',
   age : 25,
   department : web development
};

语法

对象中 delete 运算符的语法,例如

delete expression

这里,表达式应该是属性,即

delete object or
delete object.property or
delete object['property']

此运算符将返回 true 或 false。如果它删除了属性,则将返回 true。如果在删除时对象属性不存在,则将返回 true,但不会对对象产生任何影响。如果我们尝试使用 delete 关键字删除任何变量或函数,它将返回 false。

现在,让我们来看一个从上面提到的对象中删除 age 属性的示例。

示例

<!DOCTYPE html>
<html>
<body>
   <h2>Deleting an object property</h2>
   <p>Before delete a property :
      <span id="showMessage" style="color: darkgreen"></span>
   </p>
   <p>After delete a property:
      <span id="result" style="color: darkgreen"></span>
   </P>
   <script>
      let employee = {
         firstName: "Devika",
         lastName: "Rani",
         age : 25,
         role : "web developer"
      }
      document.getElementById('showMessage').innerHTML =employee.firstName + " " +employee.lastName + " is " + employee.age +" old and working as " + employee.role;
      delete employee.age; // returns as true
      document.getElementById('result').innerHTML = employee.firstName + " " +employee.lastName + " is " + employee.age +" old and working as " + employee.role;
   </script>
</body>
</html>

这里,delete 关键字用于从 employee 对象中删除 age 属性。删除 age 属性后,我们尝试从 employee 对象获取 age 属性,它显示为 undefined。

示例

让我们来看一个从对象中删除不存在的属性的示例。

<!DOCTYPE html>
<html>
<body>
   <h2>Deleting an object property</h2>
   <p>Before delete a property :
      <span id="showMessage" style="color: darkgreen"></span>
   </p>
   <p>After delete a property:
      <span id="result" style="color: darkgreen"></span>
   </P>
   <script>
      let employee = {
         firstName: "Devika",
         lastName: "Rani",
         age : 25,
         role : "web developer"
      }
      document.getElementById('showMessage').innerHTML = employee.firstName + " " +employee.lastName + " is " + employee.age +" old and working as " + employee.role;
      delete employee.age; // returns as true
      delete employee.role; // returns as true
      delete employee.salary; // returns as true
      document.getElementById('result').innerHTML =employee.firstName + " " +employee.lastName + " is " + employee.age +" old and working as " + employee.role;
   </script>
</body>
</html>

示例

让我们再来看一个删除变量的示例。

<!DOCTYPE html>
<html>
<body>
   <h2>Deleting a variable</h2>
   <p>After delete a variable:
      <span id="result"></span>
   </p>
   <script>
      let num1 = 20;
      let num2 = 30;
      let sum = (a, b) => {
         return a + b;
      }
      if(delete num1){ // returns false
         document.getElementById('result').innerHTML ="variable num is deleted."
      } else {
         document.getElementById('result').innerHTML = num1
      }
   </script>
</body>
</html>

这里,我们可以观察到 delete 对变量不起作用。即使对变量使用 delete 也不会对其产生任何影响。

示例

现在,我们将检查删除全局变量的情况。我们都知道未声明的变量将被视为全局变量。让我们来看一个示例

<!DOCTYPE html>
<html>
<body>
   <h2>Deleting a global variable</h2>
   <p id="result">
   </p>
   <script>
      value = 5;
      try{
         delete value; // returns true
         document.getElementById('result').innerHTML = value;
      }
      catch(e){
         document.getElementById('result').innerHTML = e;
      }
   </script>
</body>
</html>

Object.Prototype delete

现在,我们将检查如何删除具有原型链的对象的属性。

示例

<!DOCTYPE html>
<html>
<body>
   <h2>Deleting a prototype object property</h2>
   <p>Object value :
      <span id="check"></span>
   </p>
   <p>Object value after delete:
      <span id="checkDelete"></span>
   </p>
   <p>Object.prototype value after delete:
      <span id="checkProtoDelete"></span>
   </p>
   <script>
      function check() {
         this.value = 3;
      }
      check.prototype.value = 8;
      var newCheck = new check();

      // check.value is associated with its own property.
      document.getElementById('check').innerHTML = newCheck.value;

      // Delete the own property within the newCheck object.
      delete newCheck.value; // returns true

      // newCheck.value is still available in the prototype chain.
      document.getElementById('checkDelete').innerHTML = newCheck.value;

      // Deleting the property on the prototype.
      delete check.prototype.value; // returns true

      // The "value" property can no longer be inherited from check since it has been deleted.
      document.getElementById('checkProtoDelete').innerHTML = newCheck.value;
   </script> 
</body>
</html>

delete 方法的另一件事是,此运算符 delete 不会删除属性值,而是删除属性本身。让我们来看一个示例以详细检查

示例

<!DOCTYPE html>
<html>
<body>
   <h2>Deleting a property</h2>
   <p id = "result"></p>
   <script>
      let employee = {
         firstName: "Sarah",
         lastName: "Max",
         age: 25
      }

      let age = employee.age;
      delete employee.age;
      document.getElementById("result").innerHTML = age;
   </script>
</body>
</html>

这里,我们可以观察到输出显示 delete 运算符已删除对象的属性,但该值仍然存在于内存中。

删除数组元素

在 JavaScript 中,我们知道数组的 typeof 也是一个对象。因此,我们也可以对数组执行 delete 操作。但这里我们有一个关于数组 delete 运算符的问题,即从数组中删除元素不会影响数组的长度。删除元素的位置将显示为空。让我们来看一个例子

示例

<!DOCTYPE html>
<html>
<body>
   <h2>Deleting an array</h2>
   <p>Length of the array after delete an element :
      <span id = "arrLength"></span>
   </p>
   <p>Array elements after delete an element :
      <span id = "result"></span>
   </p>
   <script>
      let arr = [1, 2, 3]
      delete arr[1];
      document.getElementById("arrLength").innerHTML = arr.length;
      document.getElementById("result").innerHTML = arr;
   </script>
</body>
</html>

这里,我们可以看到第二个元素为空。但长度仍然相同。因此,对于从数组中删除元素,使用 pop() 或 splice() 或 shift() 方法是更好的方法。

我们已经看到了对象和变量上的 delete 运算符。我们已经看到了原型链对象上的 delete 运算符。我们已经看到了从数组中删除元素。希望本文能让你了解 JavaScript 中的 delete 运算符。

更新于: 2022-12-08

251 次浏览

启动你的 职业生涯

通过完成课程获得认证

开始学习
广告