• delete操作符


    语法

    delete expression

    expression 的计算结果应该是某个属性的引用,例如:

    delete object.property
    delete object['property']

    返回值

    对于所有情况都是true,除非属性是一个自己不可配置的属性,在这种情况下,非严格模式返回 false。在严格模式下,如果是属性是一个自己不可配置的属性,会抛出Global_objects/SyntaxError

    delete操作符与直接释放内存无关

    资源搜索网站大全 https://www.renrenfan.com.cn 广州VI设计公司https://www.houdianzi.com

    特殊情况:

    1.删除的属性不存在,那么delete将不会起任何作用,但仍会返回true。
    2.delete操作只会在自身的属性上起作用。而原型链上具有相同名称的属性可用

    function Foo() {
      this.bar = 10;
    }
    Foo.prototype.bar = 42;
    
    var foo = new Foo();
    delete foo.bar;// 返回 true,因为删除的是 foo 对象的自身属性           
    console.log(foo.bar);// foo.bar 仍然可用,因为它在原型链上可用。
    
    // 从原型上删除属性
    delete Foo.prototype.bar; 
    console.log(foo.bar);// 输出 "undefined",因为不能继承这个属性了

    3.任何使用 var 声明的属性不能从全局作用域或函数的作用域中删除。

    • delete操作不能删除任何在全局作用域中的函数(无论这个函数是来自于函数声明或函数表达式)
    • 在对象(object)中的函数是能够用delete操作删除的。

    4.何用let或const声明的属性不能够从它被声明的作用域中删除。
    5.不可设置的(Non-configurable)属性不能被移除。这意味着像Math,Array内置对象的属性以及使用Object.defineProperty()方法设置为不可设置的属性不能被删除。当一个属性被设置为不可设置,delete操作将不会有任何效果,并且会返回false。在严格模式下会抛出语法错误(SyntaxError)。
    6.删除数组元素
    使用delete操作符删除数组总某项元素时,被删除的元素会从该数组中删除,包括其索引,但是数组的length并不会改变。

    var arr = [1, 2, 3];
    delete arr[1];
    console.log(arr); // [ 1, <1 empty item>, 3 ]
    console.log(delete arr[1]); // true
    console.log(arr[1]); // undefined
    console.log(1 in arr); // false
    arr[1] = undefined;
    console.log(1 in arr); // true
  • 相关阅读:
    高德地图之 鼠标移进移出时 图标的改变
    高德地图之--海外地图
    angular表单验证
    angularJs 页面加载页面
    angularJs tab样式切换方法之一
    资源
    JavaScript规范
    H5 用 iScroll实现上拉加载 下拉刷新的功能
    ionic项目之极光推送--通知
    Day6 function
  • 原文地址:https://www.cnblogs.com/xiaonian8/p/14085573.html
Copyright © 2020-2023  润新知