1、delete
delete是删除对象的属性没有任何剩菜,剩下的唯⼀真正的⽅法,但它的⼯作⽐其“替代”设置慢100倍 object[key] = undefined
var myObject = {
\"ircEvent\": \"PRIVMSG\ \"method\": \"newURI\ \"regex\": \"^http://.*\"};
delete myObject.regex;console.log(myObject);
delete 操作符会从某个对象上移除指定属性。成功删除的时候回返回 true,否则返回 false。但是,以下情况需要重点考虑:如果你试图删除的属性不存在,那么delete将不会起任何作⽤,但仍会返回true
如果对象的原型链上有⼀个与待删除属性同名的属性,那么删除属性之后,对象会使⽤原型链上的那个属性(也就是说,delete操作只会在⾃⾝的属性上起作⽤)
任何使⽤ var 声明的属性不能从全局作⽤域或函数的作⽤域中删除。
这样的话,delete操作不能删除任何在全局作⽤域中的函数(⽆论这个函数是来⾃于函数声明或函数表达式)除了在全局作⽤域中的函数不能被删除,在对象(object)中的函数是能够⽤delete操作删除的。任何⽤let或const声明的属性不能够从它被声明的作⽤域中删除。
不可设置的(Non-configurable)属性不能被移除。这意味着像Math, Array, Object内置对象的属性以及使⽤Object.defineProperty()⽅法设置为不可设置的属性不能被删除。
2、 obj.field = undefined;
这个选择不是这个问题的正确答案!但是,如果你⼩⼼使⽤它,你可以⼤⼤加快⼀些算法。如果您delete在循环中使⽤并且在性能⽅⾯存在问题,请阅读详细解释
var obj = { field: 1 };
obj.field = undefined;
3、数组中使⽤delete
在数组中,与普通的旧对象不同,使⽤delete在表单中留下垃圾,null在数组中创建⼀个“洞”, ⽽且length不变。
var array = [1, 2, 3, 4];delete array[2];
/* Expected result --> [1, 2, 4] * Actual result --> [1, 2, null, 4] */
4、数组中使⽤splice
arrayObject.splice(index,howmany,item1,.....,itemX)
index: 必需。整数,规定添加/删除项⽬的位置,使⽤负数可从数组结 尾处规定位置。
howmany: 必需。要删除的项⽬数量。如果设置为 0,则不会删除项⽬。item1: 可选。向数组添加的新项⽬。
var arr = new Array(6)arr[0] = \"George\"arr[1] = \"John\"
arr[2] = \"Thomas\"arr[3] = \"James\"arr[4] = \"Adrew\"arr[5] = \"Martin\"
document.write(arr + \"
\")arr.splice(2,0,\"William\")
document.write(arr + \"
\")/*
*George,John,Thomas,James,Adrew,Martin
*George,John,William,Thomas,James,Adrew,Martin*/
总结
到此这篇关于JavaScript如何删除对象的某个属性的⽂章就介绍到这了,更多相关JavaScript删除对象某个属性内容请搜索以前的⽂章或继续浏览下⾯的相关⽂章希望⼤家以后多多⽀持!
因篇幅问题不能全部显示,请点此查看更多更全内容
Copyright © 2019- yrrf.cn 版权所有 赣ICP备2024042794号-2
违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com
本站由北京市万商天勤律师事务所王兴未律师提供法律服务