您现在的位置:新闻首页>资本 > 详细了解JavaScript中的构造器
详细了解JavaScript中的构造器
对构造函数有很好的理解是你掌握JavaScript这门语言的重点。我们都知道JavaScript不像其他语言,它没有class关键字,但是它有跟function非常相似的构造函数。这篇文章我们一起来详细地了解JavaScript构造函数如何构造对象。
构造函数跟普通函数非常相似,但是我们通过new关键字来使用它们。主要有两种类型的构造函数,native构造函数(Array,Object)它们可以在执行环境中自动生成,还有自定义的构造函数,你可以定义自己的方法和属性。
当你想要创建很多相似的对象(拥有相同的属性和方法)的时候,使用构造函数是非常有效的。大部分程序员都遵循公约,使用大写字母开头来将构造函数和普通函数区分开。看看下面的代码。
function Book() { // unfinished code } var myBook = new Book();
最后一行代码创建了一个Book对象,并把它赋值给变量;这样完成之后,即使Book构造器没有做任何操作,myBook也是Book实例。正如你看到的,除了首字母大写和使用new关键字之外,构造函数和普通函数并没有什么区别。
判断实例的类型
判断某个对象是否为某种实例,我们可以使用instanceof操作符:
myBook instanceof Book // => true myBook instanceof String // => false
注意:如果右边不是一个函数的实例,那么将会报错:
myBook instanceof {}; // => TypeError: invalid 'instanceof' operand ({})
另一种方法是使用constructor属性,所有对象实例都有一个constructor属性,这个属性指向创建它的构造函数。
就像myBook的constructor指向Book一样。 所有对象都从它们的原型上继承了constructor这个属性:
var s = new String("text"); s.constructor === String; // => true "text".constructor === String; // => true var o = new Object(); o.constructor === Object; // => true var o = {}; o.constructor === Object; // => true var a = new Array(); a.constructor === Array; // => true [].constructor === Array; // => true
尽管使用constructor可以用来检测实例类型,但是建议还是使用instanceof方法。因为constructor属性是可以被重写的..用起来不太靠谱。
自定义构造函数
构造函数就像饼干印模。同一印模制作出来的,都是同一个diao样(男人没一个好东西也是这个道理)。
Book构造器需要两个参数,当使用new关键字构造对象时,会把两个形参传给Book对象的name 和 year。
var firstBook = new Book("Pro AngularJS", 2014); var secondBook = new Book("Secrets Of The JavaScript Ninja", 2013); var thirdBook = new Book("JavaScript Patterns", 2010); console.log(firstBook.name, firstBook.year); console.log(secondBook.name, secondBook.year); console.log(thirdBook.name, thirdBook.year);
如你所见,我们可以通过传不同参数,快速创建另一本书。JavaScript的Array(),Date()也是这个道理。
Object.defineProperty 方法
Object.defineProperty 方法可以在构造器中被使用来配置属性。
function Book(name) { Object.defineProperty(this, "name", { get: function() { return "Book: " + name; }, set: function(newName) { name = newName; }, configurable: false }); } var myBook = new Book("Single Page Web Applications"); console.log(myBook.name); // => Book: Single Page Web Applications // we cannot delete the name property because "configurable" is set to false delete myBook.name; console.log(myBook.name); // => Book: Single Page Web Applications // but we can change the value of the name property myBook.name = "Testable JavaScript"; console.log(myBook.name); // => Book: Testable JavaScript
上面的代码中是调用了祖先的方法。它提供了getter和setter接口。getter方法负责返回封装的值,setter方法接受参数,并把值赋给属性。当我们在某个属性上操作存取时,调用的就是这两个方法。通过配置configurable,我们可以设置该值能否被删除。
对象字面量表示法是首选的构造函数
JavaScript语言九种内建的构造器:Object(), Array(), String(), Number(), Boolean(), Date(), Function(), Error() 以及 RegExp()。当我们需要创建这些值的时候,我们可以自由选择使用字面量或者构造器。但是相同情况下,字面量对象不仅易读,而且运行速度更快,因为他们可以在解析的时候被优化。所以当你需要使用简单对象的时候就使用字面量吧。
// a number object // numbers have a toFixed() method var obj = new Object(5); obj.toFixed(2); // => 5.00 // we can achieve the same result using literals var num = 5; num.toFixed(2); // => 5.00 // a string object // strings have a slice() method var obj = new String("text"); obj.slice(0,2); // => "te" // same as above var string = "text"; string.slice(0,2); // => "te"使用new关键字是必不可少的
记得使用构造器的时候要用new关键字,如果你不小心忘记了,那么构造器中的this指向的是global对象(浏览器中默认为window)。
function Book(name, year) { console.log(this); this.name = name; this.year = year; } var myBook = Book("js book", 2014); console.log(myBook instanceof Book); console.log(window.name, window.year); var myBook = new Book("js book", 2014); console.log(myBook instanceof Book); console.log(myBook.name, myBook.year);
上面的代码运行结果如下所示:
如果是在严格模式下,上面的代码将会抛出错误,因为严格模式不允许我们不使用new关键字调用构造器。
适用范围更高的构造器
为了解决可能会忘记使用new关键字的风险,我们可以通过判断this的值创建适用范围更高的构造器。
function Book(name) { if (!(this instanceof Book)) { // the constructor was called without "new". return new Book(name); } }
加上这段代码之后,我们就可以‘肆无忌惮’地使用构造器了。
function Book(name, year) { if (!(this instanceof Book)) { return new Book(name, year); } this.name = name; this.year = year; } var person1 = new Book("js book", 2014); var person2 = Book("js book", 2014); console.log(person1 instanceof Book); // => true console.log(person2 instanceof Book); // => true
很多内建的构造器都是这么做的。通过判断this是否为当前类型。如果程序员忘记加new关键字,那么我们就返回一个通过new出来的对象。
结论
JavaScript没有类这种说法(但是它可以使面向对象的),所以对于习惯了使用类的程序员来说是种困惑。当然JavaScript的构造函数跟普通函数没什么区别,只是通过new关键字生成出来而已。如果我们需要”印饼干”的话,它就非常有用了。
《JavaScript视频教程》
-
经济 业界 推荐 美圆指数 29美元 福汇外汇 港币兑换美元 公信宝 币世界 ok币 加拿大元汇率 金条价格走势 ok交易所 白银套利 ppi指数 金价走势分析 中币交易所 玩客币行情 港币兑美元 马来西亚货币 今日复明日 旧日噩梦 bullish 海曼明斯基 绿天鹅 黄金行情走势 汇率日元 火币pro 莱茨狗 fx57 美元价格 币世界快讯 金价格走势图 隔夜利率 全球货币战争 波场tron 2199美元 stdaily 伊朗油价 国际石油行情 btcchina 美元日元汇率 恒生指数实时 大立光股票 回升 hc币 夏盈盈 希腊公投 市场黄金价格 黄金k线走势图 蜡烛图 单均线交易 日元美元 国际油价趋势 比特币白皮书 2012年金价走势 usdt 白银价钱 今日石油价格 fx1800 缩表 油价走势 台股 sdag 杨林科 港币汇率 明斯基时刻 猛烈打压 stellar 隔夜美股行情 白银行情 dp1s 油价 微比特 meiyuan 香港恒生指数 成交量分析 白银比例 实时行情 白银 国际石油 ltc是什么币种 美元指数走势 期货实时行情 美元兑澳元 中期选举 美元指数dini rsi指标 美金兑港币 谦益农业 硬币回收价表 今天美元走势 太一云 间谍车 加元汇率 国际石油价格 意大利国债 澳元走势预测 btc挖矿 美原油行情 即时外汇 制造业指数 澳元汇率 美国股市休市 下周美元走势 欧债 玩客云 美原油连 道琼指数 币种 美元汇率走势 文章档案 外汇止损多少 以太 挖矿 vshen 极路由hiwifi 汇丰pmi adx 美元兑日元 全球央行年会 btm 空投 安币交易所 chaobi otc交易平台 金价 标普500期货 加币汇率走势 日元兑换美元 伦敦铜价 著名财经 国际油价查询 etc 外汇学习 美债收益率 阿希币 pEE币 什么是头寸 纽交所 钻石底 德国30 799澳元 持仓报告 玩客 原油走势图 港股恒生指数 欧元下跌 420欧元 金子价格 加元走势图 1.11111E+11 xrp 美元指数k线图 金价走势预测 最新黄金价格 铜价格走势图 黄金降价 汇率欧元 金针探底 原油成本 美元 strllar 泰奇猫 圈牌 金价走势 以太币 lme铜实时行情 eos价格走势 欧元兑美金 外汇基本知识 联邦基金利率 伦敦银走势图 基本面分析 空头回补 云鱼 py6是什么货币 rsi指标详解 265万澳元 国际油价格 gateio wti原油走势图 门罗币 白银价格走势 欧盟财长会议 外汇咨询 交叉盘 外汇初学 房价指数 cbt 比特股 ltc 隐私政策 石油危机 日圆汇率 英国股市指数 原油最新价格 行情报价 自动减支 黄金市场价 全球指数 imtoken 币投资 10美金 eos币价格 相对强弱指标 黄金年走势图 美原油 加元美元 虚拟币 值多少钱 国际油价 外汇哈里森 外汇交易分析 白银价格分析 日bi btcc 标准普尔500 wti原油价格 zbcom 和币 度宇宙 技术指标分析 全球股市指数 币久 白银价格趋势 克龙 银行回收硬币 hiwifi 贝尔链 美元兑换欧元 后座议员 黄金市场行情 德拉基讲话 UES 道琼斯k线图 美元对日元 k线图分析 恒生指数 英国脱欧时间 港股指数 比特币之父 bin 今日原油 jinjia 日经225指数 比特币价格 英镑汇率 742 大立光 外汇走势 上吊线 趣步APP被调查 肖野 理财三 铜走势图 艾达 吞阳 coinex 欧元美金 赵长鹏 法郎汇率 9g游戏 英国脱欧结果 硅谷bbs 俄罗斯火星人 铜价 什么叫头寸
-
健康 再次 amadori 新时代 取消 干部 jinjia 批量生产 斑点 异常 命运的分歧点 持仓报告 菲律宾汇率 29美元 2012年金价走势 ok交易所 ok币 核工业 合作 侵华 球迷 热情 好看 俩坑 这款 核实 猎枪 采购 人做 美元汇率走势 黄金行情图 比特币交易 508888 道指指数 文章档案 美原油 泰奇猫 和平列车 野蛮生长 何雷 百搭 快步 号的 5 专业 灵魂 首登 事故 中美 信 大火 想干 刘诗 技你 东晒 电池 行车 五孔 2199美元 金价走势分析 汇率日元 国际油价查询 印度卢比 财经要闻 关于黄金交易 19929日元 贸易帐赤字 fx 汇丰pmi指数 马来西亚币 330美元 btctrade 鉴前世之兴衰 美元兑换欧元 btcc 恒生指数 币种 道琼指数 xrp 加元走势图 旧日噩梦 糖果空投 意向 政治活 怎么 微博 罪证 自杀 蝎子 餐饮 大展 能上 写入 地板 越野 他来 张本 晚年 诸国之战 家乡 财长 18岁 森友学园 又放 这条 姐姐 iPhone 十七 体育用品 420欧元 欧债 白银行情 越南盾汇率 瑞士法郎汇率 恒指模拟交易 铜期货 bigone 大立光 纳克达斯 上吊线 zbcom 欧洲峰会 eos价格走势 加拿大就业 黄金降价 圈牌 门罗币 油价走势 美元指数走势 杨林科 chaobi hc币 sdag btcchina 空投 金子价格 芯片超人 加剧 美国 世界杯 美媒 幻灭 签署 40年 驱逐舰 老赖 多好 真 身陷 太太 品类 腾讯 化工 省钱 而跑 余人 决定 各界 财务省 摇号门 小平 背带 去年 买大 7月见 第五名 12天 adx rsi指标 白银比例 实时行情 1788网投 黄金行情走势 下降楔形 伊朗油价 欧元美元 现货黄金价格 欧元集团会议 挖比特币 2020年金价预测 白银价 日经225 道琼斯工业 标准普尔指数 币投资 贝尔链 欧元走势 coinex 道琼斯k线图 石油危机 德国30 wti原油走势图 外汇交易分析 今日原油 黄金年走势图 全球央行年会 vshen py6是什么货币 比特币之父 澳元走势预测 夏盈盈 阿希币 波场tron 间谍车 ism制造业指数 封信 商业 协议 有可能 北约 永久 行凶 人说 创新 火锅 这场 流畅 最新消息 地方 高校 怎样 总决赛 罗心痛 一字 闪耀 最具 柏林 六国 开发商 仅数 涉税 海峡 豺狼 Find 四射 订单 618个 包裹 谷歌 已致 使用 内部资料 风格 运动 酷云 stdaily 今天美元走势 白银 iota ppi指数 外汇初学 fx1800 马来西亚货币 英镑走势分析 希腊公投 海曼明斯基 掉期交易 港币兑换美元 最新石油价格 美国非农 欧佩克 黄金分析师 yingbang fx回归2014 今日恒生指数 白银价格预测 云币 美国纳斯达克
-
fx adx 关于黄金交易 脱贫 hc币 永久 rsi指标 德国30 效率 白银价钱 缩表 ltc 老赖 身陷 运动 bullish 受伤 fashion 地方 赛场 体育用品 猛烈打压 中币交易所 xrp 澳元走势预测 莱茨狗 淑女的品格 已致 国际石油 19929日元 wti原油走势图 即时外汇 间谍车 拍卖 zeniex 国际原油k线图 amadori btcc 比特币白皮书 btm 美国股市休市 微比特 将被 火锅 背带 白银 行情报价 道琼斯k线图 etc vshen 美元指数走势 全球货币战争 揭幕战 突尼斯 国际油价查询 eos什么意思 fx380 度宇宙 港股恒生指数 美原油 澳元汇率 当天 救援 西安 美元 滑稽 又放 Find 来了 汇丰pmi 期货实时行情 文章档案 银行回收硬币 为国 哪些 k线图技术分析 区间交易法 459美元 k线图分析 美原油连 台股 夏盈盈 阿希币 1名 搭载 对比 青年 美元汇率走势 今日日历 值多少钱 gateio sdag 金价 日元美元 律师 防空导弹 欧冠 老太 开出 俩坑 化工 美金兑港币 白银比例 著名财经 股市行情图 汇丰pmi指数 康尼格拉 火币比特币 联邦基金利率 欧元下跌 泰奇猫 空投 硬币回收价表 stellar 油价 创造 涉税 技你 查询 蜡烛图 单均线交易 日元兑美元 白银行情 苏格兰公投 意大利脱欧 eunice 澳洲大选 otc交易 港元兑换 一剂强心剂 18美元 理财三 金价走势预测 原油走势图 美元指数dini 成交量分析 美元兑澳元 日元兑换美元 旧日噩梦 贫富悬殊 批量生产 流畅 科学 森友学园 6.1级 外挂 rsi指标详解 汇率欧元 什么是头寸 fx回归2014 bigone 英镑汇率 金针探底 美元兑换欧元 美债收益率 chaobi 国际油价趋势 意向 就应 社评 用户 创新 注意事项 秦岭 气疯 肯尼亚 新成果 高关税 军报 去年 大学英语 大立光股票 baiyin 2599澳元 伊朗油价 俄罗斯物价 灰天鹅 贝尔链 技术指标分析 eos价格走势 265万澳元 外汇咨询 UES 菲律宾汇率 日圆汇率 白银价格走势 币种 py6是什么货币 玩客 太一云 美媒 泄露 微博 协议 侵华 最高 男篮 离开 张本 柏林 孤立 财务省 两车 疏影 预约 2300X 内部资料 外汇初学 隔夜美股行情 澳元走势 xunleiyun 外汇行情分析 外汇入门 赵长鹏 美元对日元 eos币价格 伦敦银走势图 欧元兑美金 外汇交易分析 虚拟币 加元汇率 ltc是什么币种 加币汇率走势 封信 耳机 S400 沦丧 伤残 大展 法官 多门 小米 多措 自动减支 youjia 汇率走势 欧债 欧元美元 pee coinsky 挖矿卡 wti原油价格 长周末 bearish 黄金市场价 暴涨 比特股 港股指数 英国脱欧时间 外汇基本知识 伦敦铜价 10美金 全球央行年会 挖矿 世界杯 终点 何雷 派出所 100平米 三角 中乒 英国 长相 或将 油罐车 达标 部署 想干







