随着IE的逐步追赶,目前到IE11已经能够很好的支持ECMAScript5标准了,其他的现代浏览器像firefox,chrome,opera就更不用说了。

再加上nodejs使得javascript在后台开发中得到施展的舞台,这很自然的激发了我对ECMAScript5相关的特性的求知欲望。

以此展开,写一个ECMAScript5新特性的学习笔记。

先来看看Object

  • Object.create(proto[, propertiesObject])

    create方法通过指定的原型对象(prototype object)和属性(properties)来创建一个新的对象。

    proto:即为新创建对象的prototype

    propertiesObject:带属性描述的属性对象(姑且这么翻译)

    create方法能够让我们方便的通过prototype原型链来实现“继承”:

         // super class
    var Human = function(cfg) {
    this.gender = cfg.gender;
    this.name = cfg.name;
    }; Human.prototype.sayHello = function() {
    console.log('Hello, I am ' + this.name);
    }; // sub class
    var Citizen = function(cfg) {
    this.country = cfg.country;
    // call super constructor
    Human.call(this, cfg);
    }; // prototype chain inherit
    Citizen.prototype = Object.create(Human.prototype);
    // override constructor
    Citizen.prototype.constructor = Citizen; // overwrite super class method
    Citizen.prototype.sayHello = function() {
    console.log('Hello, I am ' + this.name + ' from ' + this.country);
    }; var h = new Human({
    gender: 'female',
    name: 'lucy'
    });
    h.sayHello();
    console.log( h instanceof Human ); var c = new Citizen({
    gender: 'male',
    name: 'Andrew',
    country: 'USA'
    });
    c.sayHello();
    console.log( c instanceof Citizen);
  • Object.defineProperty(obj, prop, descriptor)

    defineProperty方法直接在一个对象上定义一个新属性,或者更改一个已存在的属性,返回对象本身。

    obj:对象

    prop: 属性名

    descriptor: 属性描述对象

    用code来做直观说明:

     /*
    enumerable 是否可列举 默认:false
    writable 是否可写 默认:false
    configurable是否可配置 默认:false
    value 默认:undefined 访问器
    get 默认:undefined
    set 默认:undefined
    */
    var o = {}; // enumerable 是否可列举
    Object.defineProperty(o, 'a', {
    value: 1,
    enumerable: false
    }); Object.defineProperty(o, 'b', {
    value: 2,
    enumerable: true
    }); Object.defineProperty(o, 'c', {
    value: 3
    // enumerable默认false
    }); o.d = 4; for(var prop in o) {
    // 输出b、d
    console.log(prop);
    } // writable 是否可写(更改值)
    // 这个特性在定义常量时比较有用
    Object.defineProperty(o, 'e', {
    value: 10,
    writable: false
    }); console.log(o.e); //
    o.e = 15; // 一般没错误抛出,若是在strict mode(严格模式下)会抛出错误
    console.log(o.e); // // configurable 是否可配置
    Object.defineProperty(o, 'f', {
    configurable: true,
    get: function() { return 10; }
    }); // 如果configurable为false,那么下面这些redefine(重定义)操作都会报TypeError
    // 如果configurable为true,那么下面这些操作均能成功,delete操作也能删除e属性
    Object.defineProperty(o, 'f', { configurable: true }); // TypeError
    Object.defineProperty(o, 'f', { enumerable: true }); // TypeError
    Object.defineProperty(o, 'f', { set: function() {} }); // TypeError
    Object.defineProperty(o, 'f', { get: function() {return 10;}}); //TypeError
    Object.defineProperty(o, 'f', { value: 12}); // TypeError console.log(o.f); //
    delete o.f; // nothing happens
    console.log(o.f); // // get, set访问器
    // 注意:有get、set的情况下,不能同存在value,writable属性,否则会报错
    var variable = 10;
    Object.defineProperty(o, 'g', {
    get: function() {
    return variable;
    },
    set: function(val) {
    variable = val;
    }
    }); console.log(o.g); //
    o.g = 14; // set(14)
    console.log(o.g); // // 补充:
    o.h = 1;
    // 相当于:
    Object.defineProperty(o, 'h', {
    value: 1,
    writable: true,
    configurable: true,
    enumerable: true
    }) ; Object.defineProperty(o, 'h', { value: 1 });
    // 相当于:
    Object.defineProperty(o, 'h', {
    value: 1,
    writable: false,
    configurable: false,
    enumerable: false
    });
  • object.defineProperties(obj, props)

    这个与defineProperty的区别在于一下子可以定义多个属性,就再不展开了。

第一部分暂时到这里结束 : ),感兴趣的同学可以直接去MDN进行了解,请点击这里

ECMAScript5之Object学习笔记(一)的更多相关文章

  1. ECMAScript5之Object学习笔记(三)

    第三部分继续... Object.getOwnPropertyDescriptor(obj, prop) 获取一个对象的属性描述符 根据"Own"这个词我们可以猜到,prop只能是 ...

  2. ECMAScript5之Object学习笔记(二)

    继续第二部分 Object.freeze(obj) 看字面意思就是“把一个对象冻结”. 下面我们来看个简单的例子以作说明: // a person instance var person = { na ...

  3. Object学习笔记

    <script type="text/javascript"> function forEach(o){ var html =""; for(var ...

  4. [javascript|基本概念|Object]学习笔记

    对象:数据和功能的集合 创建对象:new 对象类型名称 e.g.: var o = new Object(); 或 var o = new Object(省略(),不推荐) 或 var o = {}( ...

  5. JavaScript Object学习笔记二

    Object.create(proto, [propertiesObject])//创建对象,使用参数一来作为新创建对象的__proto__属性,返回值为在指定原型对象上添加自身属性后的对象 //参数 ...

  6. JavaScript Object学习笔记一

    Object.assign(target, source1, source2, ...)//用于对象的复制合并(同名属性后覆盖前)或拷贝(拷贝自身可枚举属性,不拷贝继承属性或不可枚举属性),将sour ...

  7. Object C学习笔记24-关键字总结

    学习Object C也有段时间了,学习的过程中涉及到了很多Object C中的关键字,本文总结一下所涉及到的关键字以及基本语法. 1.  #import #import <> 从syste ...

  8. Object C学习笔记22-#define 用法

    上一篇讲到了typedef 关键字的使用,可以参考文章 Object C 学习笔记--typedef用法 .而在c中还有另外一个很重要的关键字#define. 一. #define 简介 在C中利用预 ...

  9. Object C学习笔记21-typedef用法

    在上一章的学习过程中遇到了一个关键字typedef,这个关键字是C语言中的关键字,因为Object C是C的扩展同样也是支持typedef的. 一. 基本作用 typedef是C中的关键字,它的主要作 ...

随机推荐

  1. 深入理解ajax系列第八篇

    前面的话 在以前,网站的用户与后端交互的主要方式是通过HTML表单的使用.表单的引入在1993年,由于其简单性和易用性,直到电子商务出现之前一直保持着重要位置.理解表单提交,对于更深入地理解ajax是 ...

  2. 拉格朗日乘子法以及KKT条件

    拉格朗日乘子法是一种优化算法,主要用来解决约束优化问题.他的主要思想是通过引入拉格朗日乘子来将含有n个变量和k个约束条件的约束优化问题转化为含有n+k个变量的无约束优化问题. 其中,利用拉格朗日乘子法 ...

  3. Where should we fork this repository?

    韩梦飞沙  韩亚飞  313134555@qq.com  yue31313  han_meng_fei_sha 我们应该在哪里分叉这个存储库? Where should we fork this re ...

  4. BZOJ3611 HEOI2014大工程

    先建虚树,然后统计答案. 对于这个两点间最大值和最小值的操作我参考了hzwer的代码. 建虚树时注意判自环 By:大奕哥 #include<bits/stdc++.h> using nam ...

  5. [Luogu4724][模板]三维凸包(增量构造法)

    1.向量点积同二维,x1y1+x2y2+x3y3.向量叉积是行列式形式,(y1z2-z1y2,z1x2-x1z2,x1y2-y1x2). 2.增量构造法: 1)首先定义,一个平面由三个点唯一确定.一个 ...

  6. [BZOJ4557][JLOI2016]侦察守卫(树形DP)

    首先可以确定是树形DP,但这里存在跨子树的信息传递问题,这里就需要“借”的思想. f[i][j]表示i子树内所有点都被覆盖到,且i以外j层内的点都能被覆盖到 的方案数. g[i][j]表示i子树内离i ...

  7. String 字符串详解 / 常用API

    String 详解 / 常用API 简介 String 是不可改变的字符串序列.String 为字符串常量 StringBuilder 与StringBuffer 均为可改变的字符串序列.为字符串变量 ...

  8. HDU 5682 zxa and leaf 二分 树形dp

    zxa and leaf 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5682 Description zxa have an unrooted t ...

  9. C#高级编程9-目录

    C#高级编程 ===================================================== .NET体系结构 核心C# 对象与类型 继承 泛型 数组 运算符和类型强制转换 ...

  10. Window 下安装

    Window 下安装 下载地址:https://github.com/MSOpenTech/redis/releases Redis 支持 32 位和 64 位.这个需要根据你系统平台的实际情况选择, ...