JavaScript 对象学习笔记(中)
2016-07-15 21:21
525 查看
上一篇讲解了对象的概念和创建方式,详见:JavaScript 对象学习笔记(上)
Object.create()方法是ECMAScript5中定义的新的方法,可以通过任意的原型创建对象,在ECMAScript3中可以使用如下代码模型原型继承:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201907/25/089c63ef3031f7f4cac2afd1d396c9e9)
对象属性查询和设置
对象属性可以通过 (.) 或 ([]) 运算符来获取值,运算符的左侧应该是一个表达式他返回一个对象,ECMAScript3中,点运算符后面的标识符不能是保留字,例如 obj.class 或者 obj.for 是非法,如果一个对象的属性名是保留字,则必须使用方括号的形式访问它们,例如 obj[“class”] 或者 obj[“for”],在ECMAScript5中则放宽了这些限制。
Object.create()方法是ECMAScript5中定义的新的方法,可以通过任意的原型创建对象,在ECMAScript3中可以使用如下代码模型原型继承:
/** * 返回了一个继承自原型对象obj的属性的对象 * @param obj 需要继承的原型对象 */ function inherit(obj){ if(obj == null) throw TypeError();//obj是一个对象但是不能为null if(Object.create) //判断Object.create是否存在 return Object.create(obj); //存在的话直接调用该方法创建对象 var type = typeof obj; //不存在的话进一步判断obj的类型 if(type !== "object" && type !== "function")//如果obj类型既不是对象也不是函数 throw TypeError();//抛出类型错误异常 function fn() { //否则创建一个空的构造函数 fn.prototype = obj; //将该构造函数的原型对象设置为obj return new fn(); //返回创建好的对象 } } var protoObj = {a : "1"}; var obj = inherit(protoObj); console.log(obj); /** * 输出结果:如下图 */
对象属性查询和设置
对象属性可以通过 (.) 或 ([]) 运算符来获取值,运算符的左侧应该是一个表达式他返回一个对象,ECMAScript3中,点运算符后面的标识符不能是保留字,例如 obj.class 或者 obj.for 是非法,如果一个对象的属性名是保留字,则必须使用方括号的形式访问它们,例如 obj[“class”] 或者 obj[“for”],在ECMAScript5中则放宽了这些限制。
var object = {name:"tom",sex:"man"}//创建一个对象,里面有两个属性 var name = object.name;//通过点的方式获取属性值 console.log(name);//结果:tom var sex = object["sex"];//通过中括号的方式获取属性值 console.log(sex);//结果:man
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- Android学习笔记(二九):嵌入浏览器
- Android java 与 javascript互访(相互调用)的方法例子
- Python动态类型的学习---引用的理解
- JavaScript演示排序算法
- javascript实现10进制转为N进制数
- 最后一次说说闭包
- Ajax
- 2019年开发人员应该学习的8个JavaScript框架
- HTML中的script标签研究
- 对一个分号引发的错误研究
- 异步流程控制:7 行代码学会 co 模块
- ES6 走马观花(ECMAScript2015 新特性)
- JavaScript拆分字符串时产生空字符的原因
- Canvas 在高清屏下绘制图片变模糊的解决方法
- Redux系列02:一个炒鸡简单的react+redux例子