JavaScript中使用Object.create()创建对象介绍


Posted in Javascript onDecember 30, 2014

对于对象的创建,除了使用字面量和new操作符,在ECMAScript 5标准中,还可以使用Object.create()来进行。Object.create()函数接受2个对象作为参数:第一个对象是必需的,表示所创建对象的prototype;第二个对象是可选的,用于定义所创建对象的各个属性(比如,writable、enumerable)。

var o = Object.create({x:1, y:7});

console.log(o);//Object {x=1, y=7}

console.log(o.__proto__);//Object {x=1, y=7}

将null作为第一个参数调用Object.create()将生成一个没有prototype的对象,该对象将不会具有任何基本的Object属性(比如,由于没有toString()方法,对这个对象使用+操作符会抛出异常):

var o2 = Object.create(null);

console.log("It is " + o2);//Type Error, can't convert o2 to primitive type

对于仅支持ECMAScript 3标准的浏览器,可以用Douglas Crockford的方法来进行Object.create()操作:

if (typeof Object.create !== 'function') {

    Object.create = function (o) {

        function F() {}

        F.prototype = o;

        return new F();

    };

}

newObject = Object.create(oldObject);
Javascript 相关文章推荐
让你的博客飘雪花超出屏幕依然看得见
Jan 04 Javascript
jQuery使用ajaxSubmit()提交表单示例
Apr 04 Javascript
jquery实现的一个文章自定义分段显示功能
May 23 Javascript
jQuery中nextUntil()方法用法实例
Jan 07 Javascript
基于jquery实现左右按钮点击的图片切换效果
Jan 27 Javascript
超级简易的JS计算器实例讲解(实现加减乘除)
Aug 08 Javascript
[js高手之路]寄生组合式继承的优势详解
Aug 28 Javascript
vue mint-ui学习笔记之picker的使用
Oct 11 Javascript
axios进阶实践之利用最优雅的方式写ajax请求
Dec 20 Javascript
微信小程序实现团购或秒杀批量倒计时
Nov 01 Javascript
JavaScript学习笔记之数组基本操作示例
Jan 09 Javascript
vue中使用vue-cli接入融云实现即时通信
Apr 19 Javascript
JavaScript中对象property的读取和写入方法介绍
Dec 30 #Javascript
jQuery中:last选择器用法实例
Dec 30 #Javascript
JavaScript中对象property的删除方法介绍
Dec 30 #Javascript
JavaScript中检查对象property的存在性方法介绍
Dec 30 #Javascript
JavaScript中遍历对象的property的3种方法介绍
Dec 30 #Javascript
JavaScript语言对Unicode字符集的支持详解
Dec 30 #Javascript
JavaScript中的对象的extensible属性介绍
Dec 30 #Javascript
You might like
phpinfo()中Loaded Configuration File(none)的解决方法
2017/01/16 PHP
php如何获取Http请求
2020/04/30 PHP
JavaScript 捕获窗口关闭事件
2009/07/26 Javascript
form表单中去掉默认的enter键提交并绑定js方法实现代码
2013/04/01 Javascript
jquery选择器原理介绍($()使用方法)
2014/03/25 Javascript
使用原生js封装webapp滑动效果(惯性滑动、滑动回弹)
2014/05/06 Javascript
jQuery CSS()方法改变现有的CSS样式表
2014/09/09 Javascript
javascript文本框内输入文字倒计数的方法
2015/02/24 Javascript
基于Bootstrap+jQuery.validate实现表单验证
2016/05/30 Javascript
轻松实现jquery选项卡切换效果
2016/10/10 Javascript
老生常谈jquery中detach()和remove()的区别
2017/03/02 Javascript
vue中使用echarts制作圆环图的实例代码
2018/07/27 Javascript
npm配置国内镜像资源+淘宝镜像的方法
2018/09/07 Javascript
微信小程序在地图选择地址并返回经纬度简单示例
2018/12/03 Javascript
详解vue-cli3多环境打包配置
2019/03/28 Javascript
如何搭建一个完整的Vue3.0+ts的项目步骤
2020/10/18 Javascript
[03:44]2014DOTA2国际邀请赛 71专访:DK战队赛前讨论视频遭泄露
2014/07/13 DOTA
Python中optionParser模块的使用方法实例教程
2014/08/29 Python
Python实现控制台输入密码的方法
2015/05/29 Python
python多进程和多线程究竟谁更快(详解)
2017/05/29 Python
python中map()函数的使用方法示例
2017/09/29 Python
python实现计数排序与桶排序实例代码
2019/03/28 Python
python之pyqt5通过按钮改变Label的背景颜色方法
2019/06/13 Python
如何爬取通过ajax加载数据的网站
2019/08/15 Python
python爬虫增加访问量的方法
2019/08/22 Python
详解Python3中的 input() 函数
2020/03/18 Python
金牌葡萄酒俱乐部:Gold Medal Wine Club
2017/11/02 全球购物
荷兰睡眠专家:Beter Bed
2020/11/23 全球购物
Android面试宝典
2013/08/06 面试题
保洁主管岗位职责
2013/11/20 职场文书
高中毕业生生活的自我评价
2013/12/08 职场文书
中国央视网签名寄语
2014/01/18 职场文书
中国梦演讲稿教师篇
2014/04/23 职场文书
汽车机电维修工求职信
2014/09/30 职场文书
圣诞晚会主持词开场白
2015/05/28 职场文书
如何用JS实现网页瀑布流布局
2021/04/24 Javascript