• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

JavaScript 有多灵活?_js

javascript 程序员 7年前 (2018-06-21) 143次浏览 已收录 0个评论

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

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

JavaScript 有多灵活?_js

  首先,在 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 

  via:ruanyifeng

欢迎大家阅读《JavaScript 有多灵活?_js》,跪求各位点评,若觉得好的话请收藏本文,by 搞代码


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:JavaScript 有多灵活?_js

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址