javascript 之 undefined

一、用法

undefined关键字有两种用法:

1.如果一个javascript对象不具有某个属性,则返回undefined。(反之不成立)

//

var a = {};

console.log(a.name); // undefined

console.log(a.name === undefined); // true

//

但是a并不拥有name属性:

//

a.hasOwnProperty('name'); // false

//

2.用来判断一个javascript对象某个属性的值是否为undefined

var a = {};

如果对a使用赋值操作符(=)赋值为undefined时,则a将拥有这个属性。

//

a.name = undefined;   

a.hasOwnProperty('name'); // true

console.log(a.name === undefined);  // true

//

二、举例

var myObject = {
    foo: "bar",
    func: function() {
        var self = this;
        
        // bar
        console.log("outer func:  this.foo = " + this.foo);
        
        // bar
        console.log("outer func:  self.foo = " + self.foo);


        (function() {
            //直接报错,因为 foo 未定义就使用。
            //console.log("inner func:  foo = " + foo); 
            
            //读取this的foo属性。如果没有则返回 undefined.            
            console.log("inner func:  this.foo = " + this.foo); 
            
            // bar
            console.log("inner func:  self.foo = " + self.foo);
        }());

    }
};


myObject.func();

三、与delete对比

undefined是用来判断javascript对象某个属性的值是否为undefined,

但不能判断javascript对象是否拥有某个属性。

如果javascript对象不拥有某个属性,也会返回undefined。

用来将某属性的值设置为undefined,而不能用来删除某个属性。

delete是用来删除某个属性的:

//

var a = {};

a.name = undefined;

a.hasOwnProperty('name'); // true

delete a.name;

a.hasOwnProperty('name'); // false


//

—————————————

javascript函数基础系列文章

1、JavaScript之变量的作用域

2、javascript之变量类型与变量声明及函数变量的运行机制

2.1、javascript之undefined

3、javaScript之function定义

4、javascript之function的prototype对象

5、javascript之function的(closure)闭包特性

6、javascript之function的this

7、javascript之function的apply(),call()

___________

javascript面向对象编程系列文章:

1、javaScript之面向对象编程

2、javascript之面向对象编程之属性继承

3、javascript之面向对象编程之原型继承

-

-转载请注明出处:

-

引用:

http://stackoverflow.com/questions/14967535/delete-a-x-vs-a-x-undefined

相关推荐