delete (          )

delete (          )

;var  n = new Number( 1 )

console.log( n + 1 )   // 2  #请在括号内填写两行语句使得其结果为 11

-----------------------------------------------------------------------------------------------

var obj = {        }

console.log( obj + obj ) // [[object ...]...]   #请为obj添加一个属性使得结果为 2

------------------------------------------------------------------------------------------------------

上面这是啥?

写到这的时候特别想灌点水烘托出高大上的氛围,至少来两段文字波澜不惊地铺垫一下,可惜没有多余的脑细胞贡献在咬文嚼字上了,还是直奔主题吧。。

为了更好地回答上面两个问题,需要读者对JavaScript原型的本质有一个较为清晰的认识,如果你很久没有脑补过原型链在对象间穿梭的画面了,非常推荐去看下鄙人另一篇拙文:

  ------从原型链探究JavaScript这么火的原因------

首先请忽略文章标题挂羊头卖狗肉的成分,这里我想分享的是在加法操作符下js对象的具体表现:

  对象在做加法操作时首先会默认沿着原型链寻找 valueOf 方法(数字对象的valueOf仍旧返回数字类型),在任何一级原型对象找到此方法都会返回结果,可以通过下面代码得到论证:

  var f = function () {}
  f.prototype.valueOf = () => 1
  var obj = new f()
  console.log( obj + 1 ) // 2
  
  由于我已经在此实例对象的构造函数的原型里写入了 valueOf 这一方法,因此,obj在它的上一级原型就找到结果 1 并返回了。
  
  那假如沿着原型链一直寻找都没有 valueOf 方法可用,怎么办呢?这时候数字对象 Number 就会启用 toString 方法,返回一个字符串类型。看到这里的朋友可能会心一笑,原来窍门在这里,用 delete 解除原型链上所有 valueOf 方法的链接,上面那两道填空题岂不就迎刃而解了。
 
  为了解决上面两道填空题,我们不得不去寻找对象的顶级原型究竟在哪里,看过鄙人拙文的朋友应该很快就能反应过来,并填写:
 
  delete Object.prototype.valueOf
  delete Function.prototype.valueOf
 
  这样填写你会发现结果仍旧是 2 ,首先这里有两个误区,第一个误区是,虽然 Number 这个构造函数对象是由 Function 构造而来,然而它的 valueOf 方法并不是通过继承 Function 原型而来,事实上 Function 的原型里我只发现有 toString 这个方法:
 
   Number.prototype.hasOwnProperty( 'valueOf' ) // true
   Function.prototype.hasOwnProperty( 'valueOf' ) // false
  
  另一个误区是,obj 根本就不会继承 Function 的原型,这一话题我在 从原型链探究JavaScript这么火的原因 这篇文中已经提过,虽然原型链理论上会使所有实例对象也继承 Function 的原型,但 JavaScript 为了能在逻辑上修正这一‘错误’,在原型链的顶级和第二级间修改了继承规则,使得所有函数对象和实例对象采取了新的继承方法。
 
  此时,第一题的答案也就呼之欲出了:
  
  delete Object.prototype.valueOf
  delete Number.prototype.valueOf 
 
  对于第二题而,看过我在原型链中那篇文提到的继承规则,答案也是不言而喻:
  
  obj = {  valueOf : () => 1  }
 
  大家还有什么别的问题,欢迎给我留言一起讨论,转载请注出。。
  
 

JavaScript如何让1+1=11;{ } + { } = 2的更多相关文章

  1. 深入理解javascript原型和闭包(11)——执行上下文栈

    继续上文的内容. 执行全局代码时,会产生一个执行上下文环境,每次调用函数都又会产生执行上下文环境.当函数调用完成时,这个上下文环境以及其中的数据都会被消除,再重新回到全局上下文环境.处于活动状态的执行 ...

  2. 每日分享!JavaScript的鼠标事件(11个事件)

    鼠标的11个事件 具体的事件解释如下: click:按下鼠标(通常是按下主按钮)时触发. dblclick:在同一个元素上双击鼠标时触发. mousedown:按下鼠标键时触发. mouseup:释放 ...

  3. Javascript 笔记与总结(1-1)作用域

    以语言的角度学习 Js 的底层原理(与 DOM 无关):① 作用域链 ② 词法分析 ③ 闭包 ④ 面向对象(原型链) ① 作用域链 例1 <script> var c = 5; funct ...

  4. ArcGIS API for JavaScript 4.2学习笔记[11] 官方第五章Popups(弹窗)概览与解释

    直接跳过第三第四章了,第三章Layer和第四章可视化,怎么说呢,Layer是组织数据的,是Map的属性之一.可视化属于符号化编程,暂时不看. 第五章是对数据.结果的显示,类似于alert()..NET ...

  5. 对于JavaScript的函数.NET开发人员应该知道的11件事

    (此文章同时发表在本人微信公众号"dotNET每日精华文章",欢迎右边二维码来关注.) 昨天小感冒今天重感冒,也不能长篇大论.如果你是.NET开发人员,在进入前端开发领域的时候,对 ...

  6. 翻译连载 | 第 11 章:融会贯通 -《JavaScript轻量级函数式编程》 |《你不知道的JS》姊妹篇

    原文地址:Functional-Light-JS 原文作者:Kyle Simpson-<You-Dont-Know-JS>作者 关于译者:这是一个流淌着沪江血液的纯粹工程:认真,是 HTM ...

  7. JavaScript中String对象的方法介绍

    1.字符方法 1.1 charAt() 方法,返回字符串中指定位置的字符. var question = "Do you like JavaScript?"; alert(ques ...

  8. 深入理解javascript原型和闭包 (转)

    该教程绕开了javascript的一些基本的语法知识,直接讲解javascript中最难理解的两个部分,也是和其他主流面向对象语言区别最大的两个部分--原型和闭包,当然,肯定少不了原型链和作用域链.帮 ...

  9. 深入理解javascript原型和闭包系列

    从下面目录中可以看到,本系列有16篇文章,外加两篇后补的,一共18篇文章.写了半个月,从9月17号开始写的.每篇文章更新时,读者的反馈还是可以的,虽然不至于上头条,但是也算是中规中矩,有看的人,也有评 ...

随机推荐

  1. linux 线程详解

    线程 是计算机中独立运行的最小单位,运行时占用很少的系统资源.可以把线程看成是操作系统分配CPU时间的基本单元.一个进程可以拥有一个至多个线程.它线程在进程内部共享地址空间.打开的文件描述符等资源.同 ...

  2. Java面向对象编程思想

    面向对象三个特征:封装.继承.多态封装:    语法:属性私有化(private).提供相对应的get/set 的方法进行访问(public). 在set/get的方法中对属性的数据 做相对应的业务逻 ...

  3. Shell编程实战

    Shell编程实战   为什么要学习Shell编程 Shell脚本语言是实现Linux/Unix系统管理及自动化运维所必须的重要工具,Linux系统的底层以及基础应用软件的核心大都涉及Shell脚本的 ...

  4. json、demjson

    一.json 概述: json.dumps():将 Python 对象编码成 JSON 字符串, dic -> json str json.dump()  :将 Python 对象保存成 JSO ...

  5. Python 12306登陆详细分析及操作

    前面的话: 1.第一次尝试爬虫,登陆12306,有不足的地方,望大家留言告知,谢谢. 2.前面引入了一个requests模块,我不多说,大家都知道干啥的.还有config是我的一个配置文件,因为其中涉 ...

  6. Qt笔记之QGADGET

    QGADGET宏类似于Q_OBJECT宏,是一个万能容器,至于这个宏所实现的功能,我也不懂,Q_OBJECT宏的功能到时了解一些,我想他们应该差不多,要想使用从Q_OBJECT继承来的类,就得在一开始 ...

  7. centos 系统上如何把python升级为3

    第一种方式: SCL 源目前由 CentOS SIG 维护,除了重新编译构建 Red Hat 的 Software Collections 外,还额外提供一些它们自己的软件包. 该源中包含不少程序的更 ...

  8. java并发中的Semaphore

    什么是Semaphore Semaphore可以控制某个资源可被同时访问的个数(locks和synchronized锁,在任何时刻只允许一个任务访问一个资源),通过acquire()获取一个许可,如果 ...

  9. mysql5.5.28在Linux下的安装

    1.       下载mysql 在http://dev.mysql.com/downloads/mysql/ 官网上下载mysql-5.5.28-linux2.6-i686.tar.gz. 2.   ...

  10. B-食物链-经典并查集

    动物王国中有三类动物A,B,C,这三类动物的食物链构成了有趣的环形.A吃B, B吃C,C吃A. 现有N个动物,以1-N编号.每个动物都是A,B,C中的一种,但是我们并不知道它到底是哪一种. 有人用两种 ...