JavaScript 是一种灵活的语言,表达力极强,我来举一个例子,保证让很多人大吃一惊。

本文受到了 Kyle Simpson 的文章《Iterating ES6 Numbers》的启发。

首先,在 Number.prototype 对象上,部署一个 add 方法。



Number.prototype.add = function (x) {return this + x;
};

上面代码为 Number 的实例定义了一个 add 方法。(如果你对这种写法不熟悉,建议先阅读我写的《JavaScript 面向对象编程》。)

由于 Number 的实例就是数值,在数值上调用某个方法,数值会自动转为实例对象,所以就得到了下面的结果。



8['add'](2)
// 10

上面代码中,调用方法之所以写成8['add'],而不是8.add,是因为数值后面的点,会被解释为小数点,而不是点运算符。

将数值放在圆括号中,就可以使用点运算符调用方法了。



(8).add(2)
// 10

其实,还有另一种写法。



8..add(2)
// 10

上面代码的第一个点解释为小数点,第二个点解释为点运算符。为了语义清晰起见,下面我统一采用圆括号的写法。

由于add方法返回的还是数值,所以可以链式运算。



Number.prototype.subtract = function (x) {return this - x;
};(8).add(2).subtract(4)
// 6

上面代码在Number对象的实例上部署了subtract方法,它可以与add方法链式调用。

如果使用方括号调用属性,写法会很古怪。



8["add"](2)["subtract"](4)
// 6

我们还可以部署更复杂的方法。



Number.prototype.iterate = function () {var result = [];for (var i = 0; i <= this; i++) {result.push(i);}return result;
};(8).iterate()
// [0, 1, 2, 3, 4, 5, 6, 7, 8]

上面代码在 Number 对象的原型上部署了 iterate 方法,可以将一个数值自动扩展为一个数组。

总之,现在我们可以在数值上直接调用方法了,但是后面一对圆括号看着有点碍眼,有没有可能去掉圆括号呢?也就是说,能不能将下面的表达式



(8).double().square()

写成另一种样子?



(8).double.suqare

这是可以做到的。

ES5规定,每个对象的属性都有一个取值方法get,用来自定义该属性的读取操作。



Number.prototype = Object.defineProperty(Number.prototype, "double", {get: function (){return (this + this)} }
);Number.prototype =  Object.defineProperty(Number.prototype, "square", {get: function (){return (this * this)} }
);

上面代码在 Number.prototype 上定义了两个属性 double 和 square ,以及它们的取值方法 get 。

因此,在任一数值上,读取这两个属性,就可以写成下面的样子。



(8).double.square
// 256

也可以改用方括号运算符。



8["double"]["square"]
// 256

(完)

JavaScript 有多灵活?相关推荐

  1. OOJ-面向对象的JAVASCRIPT(二)

    本文继上篇文章介绍javascript 匿名函数以及闭包的特性 1.什么叫匿名函数? 匿名函数:就是没有函数名的函数. 函数是JavaScript中最灵活的一种对象,这里只是讲解其匿名函数的用途. 1 ...

  2. Javascript中的类实现

    Javascript本身并不支持面向对象,它没有访问控制符,它没有定义类的关键字class,它没有支持继承的extend或冒号,它也没有用来支持虚函数的virtual,不过,Javascript是一门 ...

  3. JavaScript装逼指南

    如何写JavaScript才能逼格更高呢?怎样才能组织JavaScript才能让别人一眼看出你不简单呢?是否很期待别人在看完你的代码之后感叹一句"原来还可以这样写"呢?下面列出一些 ...

  4. Javascript的匿名函数与自执行

    函数是JavaScript中最灵活的一种对象,这里只是讲解其匿名函数的用途.匿名函数:就是没有函数名的函数. 函数的定义,大致可分为三种方式: 第一种:这也是最常规的一种 1 2 3 function ...

  5. 盘点JavaScript函数的基本知识

    本文旨在提供web开发人员必须了解的所有JavaScript函数的基本知识. 函数于软件开发者而言并不是什么奇幻世界.如果你的日常活动涉及到编码,哪怕是一点点,那么在一天结束的时候,你一定创建/修改了 ...

  6. JavaScript中的匿名函数及函数的闭包

    1.匿名函数 函数是JavaScript中最灵活的一种对象,这里只是讲解其匿名函数的用途.匿名函数:就是没有函数名的函数. 1.1 函数的定义,首先简单介绍一下函数的定义,大致可分为三种方式 第一种: ...

  7. javascript 定义类(转载)

    Javascript本身并不支持面向对象,它没有访问控制符,它没有定义类的关键字class,它没有支持继承的extend或冒号,它也没有用来支持虚函数的virtual,不过,Javascript是一门 ...

  8. JavaScript面向对象——多继承的实现与理解

    JavaScript面向对象--实现并理解JavaScript多继承 多继承: 说明:在JavaScript中继承是依赖于原型prototype链实现的,只有一条原型链,理论上是不支持继承多个父类的. ...

  9. 教你如何塑造JavaScript牛逼形象

    如何写JavaScript才能逼格更高呢?怎样才能组织JavaScript才能让别人一眼看出你不简单呢?是否很期待别人在看完你的代码之后感叹一句"原来还可以这样写"呢?下面列出一些 ...

最新文章

  1. 5分钟速通 AI 计算机视觉发展应用
  2. asp.net开发中自定义网站的目录
  3. 教你如何阅读Oracle数据库官方文档
  4. 【技术干货】浏览器工作原理和常见WEB攻击 (下)
  5. 判断是否为自然数java_java判断输入的是否是自然数
  6. bic,orr——设置某些位为0或者1
  7. 【python】Python简介及优缺点
  8. 吴恩达神经网络和深度学习-学习笔记-26-迁移学习(transfer learning)
  9. java 右对齐_字符串对齐器(左对齐、居中、右对齐)
  10. linux 软防火墙 DDOS,Linux iptables防火墙详解 + 配置抗DDOS攻击策略实战
  11. 前端播放二进制语音流
  12. 虚拟机安装教程win7_虚拟机安装系统教程
  13. cc2530期末试卷_ZigBee期末试题.docx
  14. 线上虚拟展馆增强观众沉浸式体验感
  15. An overview of color constancy algorithms论文笔记
  16. c语言printf使用方法,C/C++语言printf命令使用方法
  17. Servlet的一些操作
  18. 基于Matlab的开环Buck降压斩波电路Simulink仿真电路模型搭建
  19. 《有限与无限的游戏》第一章 世上至少有两种游戏:经典摘抄(3)
  20. optilex 7090 sff 不支持kingston 内存条的原因分析

热门文章

  1. intellij idea run configurations配置共享
  2. 设置Eclipse的workspace路径
  3. therefore/so/hence/then/accordingly/Thus
  4. Skype for Business Server 2015-10-ADFS-2-配置
  5. ubuntu14.04安装dropbox
  6. 在Xcode6中添加prefix.pch文件
  7. Centos 6.5 64位双网卡绑定
  8. The organization of a typical MVC application
  9. 数据速率、载波频率和带宽的关系
  10. Linux多线程同步的几种方式