ES5

  • Object.create(prototype, descriptors)

      //创建对象
    var o1 = {foo:'bar'};
    var o2 = new Object();
    //Object.create(proto,[descriptors]);
    var o3 = Object.create(null); function Person(name) {
    this.name = name;
    }
    var p1 = new Person('sindy');
    var p2 = Object.create(Person.prototype, {
    age: {
    value: 18,
    writable: false,
    enumerable: false,
    configurable: true,
    //value , writable 和 getter setter函数不能同时设置
    /*get: function () {
    if (typeof age === 'undefined') {
    return 'not set age value yet';
    } else {
    return 'your age:' + age;
    }
    },
    set: function (a) {
    age = a;
    if (this.cTime == 0) {
    console.log('set age OK');
    this.cTime++;
    } else {
    console.log('change age OK');
    }
    }
    },*/
    cTime: {
    value: 0,
    writable: true
    }
    });
  • Object.defineProperty(object, propertyName, descriptor)

      var p1 = new Person('alice');
    Object.defineProperty(p1, 'name', {value:'alice2', writable:true, enumerable: false, configurable: false});
    console.log(p1.name); //=> alice2
    delete p1.name; //=> false configurable==flase,不能defineProperty重定义属性特性
    Object.defineProperty(p1, 'name', {value:'kk', enumerable: true}); //=>error
  • Object.defineProperties(object, descriptors)

    var p1 = new Person('alice');

    Object.defineProperties(p1,{

    skill:{

    value: 'singing',

    writable: true,

    enumerable: true,

    configurable: false

    },

    age: {

    value: 18,

    writable: true,

    enumerable: true,

    configurable: false

    }

    });

    p1.age //18

    p1.skill //singing

  • Object.getOwnPropertyDescriptor(obj, propertyName)

    获取自有属性的descriptor

      function Person (n){ this.name = n; }
    Person.prototype = {
    constructor: Person,
    hi: function(name){ console.log('hi,'+name);}
    };
    var p1 = new Person('alice');
    var nameDescriptor = Object.getOwnPropertyDescriptor(p1, 'name');//=>{value:'alice', enumerable: true, writable: true, configurable: true} var des = Object.getOwnPropertyDescriptor(p1, 'hi');//=>undefined
  • Object.getOwnPropertyNames(obj)

    获取对象所有的自有属性名

      //接上
    p1.age = 11;
    var props = Object.getOwnPropertyNames(p1); //=> ['name', 'age']
  • Object.preventExtensions(obj)

    禁止扩展对象,即不能添加属性到对象上。

      //接上
    Object.preventExtensions(p1);
    p1.home = 'HK';
    console.log(p1.home); //=> undefined
  • Object.isExtensible(obj)

    判断对象是否可扩展

      //接上
    Object.isExtensible(p1);//=> false
  • Object.seal(obj) , Object.isSealed(obj)

    若对象为isSeal状态则不能添加或删除属性, 但可以修改现有属性的值

      //接上
    Object.seal(p1);
    Object.isSealed(p1); //true
    delete p1.name;//=>false
    p1.like = 'shopping';
    console.log(p1.like); //=> undefined
  • Object.freeze(obj) , Object.isFrozen(obj)

    冻结对象(不能添加或删除属性,不能修改现有属性) freeze -> seal -> configurable:false 限制的严格程度递减

      Object.freeze(p1);
    Object.isFrozen(p1); //=> true
    p1.name = 'alice2';
    console.log(p1.name); //=> alice
    p1.school = 'hkzw';
    console.log(p1.school); //=> undefined
  • Object.getPrototypeOf(obj);

    获取对象的原型对象

      var proto = Object.getPrototypeOf(p1);//=>{constructor: Person, hi: function(){..}}
  • Array.isArray(arg)

  • [].indexOf(val,[pos])

  • [].lastIndexOf(val, [pos])

  • [].every(fn(v, i, arr),[context])

  • [].some(fn(v,i, arr), [context])

  • [].forEach(fn(v, i, arr), [context])

  • [].filter(fn(v, i, arr), [context])

  • [].map(fn(v, i, arr), [context]);

  • [].reduce(fn(prev, curr, i, arr), [primitive]);

  • [].reduceRight(fn(prev, curr, i, arr), [primitive]);

  • new Date().toJSON()

    序列化日期对象 输出: "2016-03-14T07:36:09.602Z"

  • String.prototype.trim

    删除字符串两端空格 (" touch ").trim(); => touch

es5 api的更多相关文章

  1. js基础知识温习:构造函数与原型

    构造函数 构造函数主要用于初始化新对象.按照惯例,构造函数名第一个字母都要大写. 构造函数有别于其它函数在于它使用new操作符来调用生成一个实例对象.换句话说,如果一个函数使用new操作符来调用,则将 ...

  2. [Effective JavaScript 笔记]第31条:使用Object.getPrototypeOf函数而不要使用__proto__属性

    ES5引入Object.getPrototypeOf函数作为获取对象原型的标准API,但由于之前的很多js引擎使用了一个特殊的__proto__属性来达到相同的目的.但有些浏览器并不支持这个__pro ...

  3. ES5对Array增强的9个API

    为了更方便的对Array进行操作,ES5规范在Array的原型上新增了9个方法,分别是forEach.filter.map.reduce.reduceRight.some.every.indexOf ...

  4. 关于ES3、ES5、ES6以及ES7所有数组的方法(api)的总结

    起因:工作用经常用到操作数组的方法,这里进行一下总结,我尽量以简洁的语言概括每个方法(api)的作用.如果您想快速定位,可以Control+F 然后搜相应的方法即可定位 :) ES3的数组方法 joi ...

  5. ES5新增数组方法测试和字符串常见API测试

    首先是ES5新增数组方法测试: <!DOCTYPE html><html lang="en"><head> <meta charset=& ...

  6. 学习笔记-es5新增的一些数组的API(不全)-字符串-字符串API(不全)

    ### es5新增的数组的api + indexOf() 搜索数组中的元素,并返回它所在的位置. arr.indexOf(str,index) 参数: str为要查找的字符串 index为开始查找的下 ...

  7. ES5新特性:理解 Array 中增强的 9 个 API

    为了更方便的对JS中Array进行操作,ES5规范在Array的原型上新增了9个方法,分别是forEach.filter.map.reduce.reduceRight.some.every.index ...

  8. ES5.X相关API和技巧汇总

    https://blog.csdn.net/laoyang360/article/details/77412668

  9. 【转】浅谈JavaScript、ES5、ES6

    什么是JavaScript JavaScript一种动态类型.弱类型.基于原型的客户端脚本语言,用来给HTML网页增加动态功能.(好吧,概念什么最讨厌了) 动态: 在运行时确定数据类型.变量使用之前不 ...

随机推荐

  1. iOS移动支付——支付宝支付

    这篇博客总结得很好,我只对在iOS上集成支付宝做简洁的步骤总结. http://www.it165.net/pro/html/201402/9376.html iOS集成支付宝支付的步骤: 准备工作的 ...

  2. css透明背景兼容方案

    css透明是一个技术活,因为这里面涉及到了IE8及以下版本不兼容opacity这个css3属性,而filter:alpha(opacity=80)这个值则是不兼容IE6.网上比较流行的透明css是这样 ...

  3. 读取本地HTML的小说阅读器应用源码项目

    该源码是一个不错的读取本地HTML的小说阅读器,读取本地HTML的小说阅读器,并且源码也比较简单的,非常适合我们的新手朋友拿来学习,有兴趣的朋友研究下. 源码下载: http://code.662p. ...

  4. 製程能力介紹(SPC introduction) ─ Cpk之製程能力解釋

    Cpk之製程能力解釋 Cpk就是綜合考慮精度與準度的製程能力指標. Cpk=(1-Ck)‧Cp 也就是在考慮Cp的同時,再考慮乘上一個(1-Ck)係數,去彌補Cp之不足,此係數最大時為1,也就是(Ck ...

  5. c# webBrowser 获取Ajax信息 .

    c#中 webbrowser控件对Ajax的执行,没有任何的响应,难于判断Ajax是否已经执行完毕,我GG了一下午,找到一个方法,介绍一下: 假如在页面中有个<div id=result> ...

  6. Sprite Kit编程指南中文版下载

    下载地址:http://download.csdn.net/detail/xin814/6032573 关于Sprite Kit 重要提示:  这是API或开发技术的一个初版文档.虽然本文档的技术准确 ...

  7. java入门学习(九) 算术运算符

    请大家关注我的博客www.taomaipin.com 运算符在java基础中也占有着举足轻重的位置,我们当然要学会它.java 其实和其他计算机语言一样,基本的算术运算符基本一样,让我们看看 有哪些算 ...

  8. libcurl使用示例

    远程下载文件,并将http 头信息存放内存中以及文件大小等相关信息: #include <stdio.h> #include <curl/curl.h> #include &l ...

  9. pl/sql developer 编码格式设置(转)

    一.pl/sql developer 中文字段显示乱码 原因:因为数据库的编号格式和pl /sql developer的编码格式不统一造成的. 二.查看和修改oracle数据库字符集: select ...

  10. 使用CSS3伸缩盒实现图片垂直居中

    用CSS实现图片垂直居中的方法有很多,针对移动端设备可以用CSS3伸缩盒来实现图片垂直居中. 代码如下: <div class="box"> <img src=& ...