JavaScript引用类型(Object 类型)

来源:互联网 发布:分贝测试软件 编辑:程序博客网 时间:2024/06/05 06:52

引用类型的值(对象)是引用类型的一个实例。在ECMAScript中,引用类型是一种数据结构,用于将数据和功能组织在一起。
引用类型有时候也被称为对象定义,因为它们描述的是一类对象所具有的属性和方法。

var person = new Object();

这行代码创建了Object引用类型的一个新实例,然后把该实例保存在变量person中。

Object类型:
创建Object实例的方式有两种:

①:使用new操作符后跟Object构造函数

var person = new Object();person.name = "Bob";person.age = 18;

②:使用对象字面量表示法:

var person = {    name : "Bob",    age : 18,};

在使用对象字面量表示语法时,属性名也可以使用字符串:

var person = {    "name" : "Bob",    "age" : 18,    5 : true};

这个例子会创建一个对象,包含三个属性:name、age 和 5。但这里的属性名会自动转换为字符串。

另外,使用对象字面量语法时,如果留其空花括号,则可以定义只包含默认属性和方法的对象。如下:

var person  = {};    //与new Object()相同person.name = "Bob";person.age = 18;

对象字面量也是向函数传递大量可选参数的首选方式,例如:

function displayInfo(args) {    var output = "";    if(typeOf args.name == "string") {        output += "Name: " + args.name + "\n";    }    if(typeOf args.name == "number") {        output += "Age: " + args.age + "\n";    }    alert(output);}displayInfo({    name: "Bob",    age: 18;})displayInfo({    name: "Tom";});

上述例子中,函数displayInfo()接受一个名为 args 的参数,这个参数可能带有一个名为 name 或 age 的属性,也可能两者都有或都没有。在这个函数内部,通过 typeOf 操作符来检测每个属性是否存在,然后再基于相应的属性来构建一条显示的信息。然后调用了两次这个函数,每次都使用一个对象字面量来指定不同的数据。这两次调用传递的参数虽然不同,但函数都能正常执行。

一般来说,访问对象属性时使用的都是点表示法,这也是很多面向对象语言中的通用的语法,不过在 JavaScript 也可以使用方括号[ ]表示法来访问对象的属性。这种语法,应该将要访问的属性以字符串的形式放在方括号[ ]中,如下:

alert(person["name"]  //"Bob"alert(person.name)    //"Bob"

从功能上看,这两种访问对象属性的方法没有任何区别。但方括号[ ]语法主要优点是可以通过变量来访问属性,例如:

var propetryName = "name";alert(person[propetryName]);   //"Bob"

通常,除非必须使用变量来访问属性,否则建议使用点表示法。

0 0