重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章主要讲解了“JavaScript对象有哪几类”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript对象有哪几类”吧!
创新互联建站专注于企业全网营销推广、网站重做改版、余干网站定制设计、自适应品牌网站建设、HTML5建站、成都做商城网站、集团公司官网建设、成都外贸网站建设公司、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为余干等各大城市提供网站开发制作服务。三类JavaScript对象
内置对象:由ECMAScript定义的对象或类。例如,数组、函数、日期和正则表达式。
宿主对象:由JavaScript解释器所嵌入的宿主环境定义的。如HTMLElement
自定义对象:由运行中的JavaScript定义的对象
自有属性:直接在对象中定义的属性
继承属性:在对象的原型对象中定义的属性
(1)、对象直接量
var empty={}; var point={x:1,y:1};
(2)、通过new创建对象
关键字new后跟函数调用,这里函数称为构造函数
var o=new Object(); //var o={}; function Person(name,age){ this.name=name; this.age=age; } var p=new Person("John",32);
(3)、原型
每个JavaScript对象(null)除外都和另外一个原型对象相关联,每一个对象都从原型继承属性。
所有通过直接量创建的对象都具有同一个原型对象,并可以通过Object.prototype获得对原型对象的引用。
通过new关键字创建的对象的原型就是构造函数的prototype属性值。new Array()的原型Array.prototype。
没有原型的对象不多如:Object.prototype,所有内置构造函数都具有一个继承自Object.prototype的原型。
(4)、Object.create()
Object.create()静态函数,第一个参数为对象的原型,可以通过传入null创建一个没有原型的对象。
var o1=Object.create(null); var o2=Object.create(Object.prototype); //var o2={};
对象通过.或[]运算符来获取属性的值。JavaScript对象都是关联数组。属性不存在返回undefined的,不能访问undefined对象的属性,否则抛出异常。
var len = book && book.subtitle && book.subtitle.length;
删除属性:delete运算符,总是返回true,只能删除自有属性。
检测属性
in运算符:检查自有属性和继承属性
hasOwnProperty():检查自有属性
propertyIsEnumerable():检查自有属性且是可枚举的
for/in枚举属性
属性的getter和setter
ECMAScript中属性值可以用一个或两个方法代替,就是getter或setter称为"存取器属性"。利用关键字set和get来声明。
属性特性:可写、可枚举、可配置
ECMAScript中定义一个名为"属性描述符"的对象,这个对象代表属性所具有的特性。
数据属性的描述符有:value、writeable、enumerable和configurable
存取属性的描述符有:get、set、enumerable和configurable
通过静态方法返回对象的特定属性的描述符
Object.getOwnPropertyDescriptor({x:1},"x");
Object.defineProperty
(1) 原型属性ES5中通过Obejct.getPropertyOf()传入对象可以查询原型,一般可以o.constructor.prototype来获得。 p.isPropertyOf(o) 检测p是否是o的原型。(2) 类属性对象的类属性是指一个字符串,用以表示对象的类型信息。
function classof(o) { if(o === null) return "Null"; if(o === undefined) return "Undefined"; return Object.prototype.toString(o).slice(8,-1); }
(3)可扩展性对象的可扩展性表示是否可以给对象添加新属性。所有内置对象和自定义对象都是显示可扩展的,宿主对象的可扩展性是由JavaScript引擎定义的。
感谢各位的阅读,以上就是“JavaScript对象有哪几类”的内容了,经过本文的学习后,相信大家对JavaScript对象有哪几类这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联网站建设公司,,小编将为大家推送更多相关知识点的文章,欢迎关注!