JavaScript数据类型(续)
2015-06-18 00:00
671 查看
6.Object
ECMAScript中的所谓的对象就是一组数据和功能的集合。对象可以通过执行new操作符后跟要创建的对象类型的名称来创建。如下面例子:
如果不给构造函数传递参数,则可以省略后面的那一对圆括号。如下面例子:
在ECMAScript中,Object类型是所有它的实例的基础。Object类型所具有的任何属性和方法也同样存在与更具体的对象中。
Object的每个实例对具有下列属性和方法:
constructor:保存着用于创建当前对象的函数。下面是例子:
hasOwnProperty(propertyName):用于检查给定的属性在当前对象实例中(而不是在实例的原型中)是否存在。其中,作为参数的属性名(propertyName)必须以字符串形式指定。测试例子:
isPrototypeOf(object):用于检查传入的对象是否是另一个对象的原型。测试例子:
propertyIsEnumerable(propertyName):用于检查给定的属性是否能够使用for-in语句来枚举。
toLocalString():返回对象的字符串表示,该字符串与执行环境的地区对应。
toString():返回对象的字符串表示。
valueOf():返回对象的字符串、数值或布尔值表示。
ECMAScript中的所谓的对象就是一组数据和功能的集合。对象可以通过执行new操作符后跟要创建的对象类型的名称来创建。如下面例子:
var o = new Object();
如果不给构造函数传递参数,则可以省略后面的那一对圆括号。如下面例子:
var o =new Object;//有效,但不推荐省略圆括号
在ECMAScript中,Object类型是所有它的实例的基础。Object类型所具有的任何属性和方法也同样存在与更具体的对象中。
Object的每个实例对具有下列属性和方法:
constructor:保存着用于创建当前对象的函数。下面是例子:
//定义constructor函数 function Person(name,age){ this.name = name; this.age = age; } //赋值给变量 var person = new Person("Tom",20); console.log(person.constructor);//打印"function Person(name,age){this.name = name;this.age = age;}"
hasOwnProperty(propertyName):用于检查给定的属性在当前对象实例中(而不是在实例的原型中)是否存在。其中,作为参数的属性名(propertyName)必须以字符串形式指定。测试例子:
//定义constructor函数 function Person(name,age){ this.name = name; this.age = age; } Person.prototype.age=30; //赋值给变量 var person = new Person("Tom",20); console.log(person.hasOwnProperty("name"));//打印"true" console.log(Person.prototype.hasOwnProperty("name"));//打印"false" console.log(Person.prototype.hasOwnProperty("age"));//打印"true"
isPrototypeOf(object):用于检查传入的对象是否是另一个对象的原型。测试例子:
//定义constructor函数 function Person(name,age){ this.name = name; this.age = age; } Person.prototype.age=30; //赋值给变量 var person = new Person("Tom",20); console.log(Person.prototype.isPrototypeOf(person));//打印"true"
propertyIsEnumerable(propertyName):用于检查给定的属性是否能够使用for-in语句来枚举。
//定义constructor函数 function Person(name,age){ this.name = name; this.age = age; } //赋值给变量 var person = new Person("Tom",20); console.log(person.propertyIsEnumerable("name"));//打印"true" console.log(person.propertyIsEnumerable("age"));//打印"true" for(item in person){ console.log(item+":"+person[item]); }
toLocalString():返回对象的字符串表示,该字符串与执行环境的地区对应。
//定义constructor函数 function Person(name,age){ this.name = name; this.age = age; } //赋值给变量 var person = new Person("Tom",20); console.log(person.toLocaleString());//打印"[object Object]"
toString():返回对象的字符串表示。
//定义constructor函数 function Person(name,age){ this.name = name; this.age = age; 7fe8 } //赋值给变量 var person = new Person("Tom",20); console.log(person.toString());//打印"[object Object]"
valueOf():返回对象的字符串、数值或布尔值表示。
//定义constructor函数 function Person(name,age){ this.name = name; this.age = age; } Person.prototype.sex="man"; //赋值给变量 var person = new Person("Tom",20); console.log(person.valueOf());
相关文章推荐
- Javascript下的urlencode编码解码方法decodeURIComponent()
- JavaScript 全半角转换
- 最简洁短小的 JavaScript 判定 IE 浏览器
- JS计算每个字符出现的次数
- javascript通用循环遍历方法forEach
- JS中的!=、== 、!==、===的用法和区别
- 如何使用JavaScript和正则表达式进行数据验证
- currentstyle 和 getComputedStyle—JS学习笔记2015-6-17(第59天)
- 理解Javascript_03_javascript全局观
- 理解Javascript_02_理解undefined和null
- 理解Javascript_01_理解内存分配
- FastJSON
- 基于js的网页计算器实现
- js删除提示的插件实现
- javascript数组基础知识(一)
- JS练习题之字符串一
- JavaScript 的 Promise
- smarty向js传递变量时应该注意的问题
- js跨域问题
- JSP九大内置对象2015-06-17