JavaScript如何删除属性及其值

JavaScript如何删除属性及其值

在JavaScript中,可以使用delete操作符来删除对象的属性及其值。delete操作符会从对象中移除指定的属性,如果删除成功,返回true;如果属性不存在或无法删除,返回false

示例代码

javascript 复制代码
let obj = {
    name: "Alice",
    age: 25,
    city: "New York"
};

// 删除 'age' 属性
delete obj.age;

console.log(obj); // 输出: { name: "Alice", city: "New York" }

// 尝试删除不存在的属性
let result = delete obj.gender;
console.log(result); // 输出: true (即使属性不存在,delete 也会返回 true)

// 删除成功
result = delete obj.city;
console.log(result); // 输出: true
console.log(obj); // 输出: { name: "Alice" }

注意事项

  1. 不可配置的属性 :如果属性是不可配置的(即configurablefalse),delete操作符无法删除该属性,并且会返回false

    javascript 复制代码
    let obj = {};
    Object.defineProperty(obj, 'name', {
        value: 'Alice',
        configurable: false
    });
    
    let result = delete obj.name;
    console.log(result); // 输出: false
    console.log(obj.name); // 输出: "Alice"
  2. 全局变量和函数delete操作符不能删除使用varletconst声明的变量或函数。

    javascript 复制代码
    var x = 10;
    console.log(delete x); // 输出: false
    
    function foo() {}
    console.log(delete foo); // 输出: false
  3. 数组元素 :虽然可以使用delete删除数组元素,但这会在数组中留下一个undefined的空位,而不会改变数组的长度。

    javascript 复制代码
    let arr = [1, 2, 3];
    delete arr[1];
    console.log(arr); // 输出: [1, undefined, 3]
    console.log(arr.length); // 输出: 3

总结

  • delete操作符用于删除对象的属性。
  • 如果属性不存在或无法删除,delete会返回true
  • delete不能删除使用varletconst声明的变量或函数。
  • 删除数组元素会留下undefined的空位,不会改变数组长度。

更多vue相关插件及后台管理模板可访问vue admin reference,代码详情请访问github

相关推荐
浅影歌年25 分钟前
vue3模块中引用公共css变量文件
前端
盼哥PyAI实验室1 小时前
从搭建到打磨:我的纯前端个人博客开发复盘
前端·javascript
前端初见1 小时前
2025前端面试题大合集
前端
用户904706683571 小时前
vue3.5新特性——useTemplateRef
前端
嘉琪0012 小时前
vue3+ts面试题(一)JSX,SFC
前端·javascript·react.js
何贤2 小时前
🪐 行星科技概念官网!Hero Section 回归!(Three.js ✨)
前端·javascript·three.js
前端拿破轮2 小时前
ReactNative从入门到性能优化(一)
前端·react native·客户端
码界奇点2 小时前
Java Web学习 第1篇前端基石HTML 入门与核心概念解析
java·前端·学习·xhtml
云枫晖2 小时前
Webpack系列-开发环境
前端·webpack
Rverdoser2 小时前
制作网站的价格一般由什么组成
前端·git·github