首页 > web前端 > js教程 > 正文

JavaScript 有多灵活?

伊谢尔伦
发布: 2016-11-24 09:44:00
原创
1113人浏览过

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

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

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

Number.prototype.add = function (x) {
  return this + x;
};
登录后复制

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

立即学习Java免费学习笔记(深入)”;

  由于 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方法链式调用。

思远企业网站管理系统1.0
思远企业网站管理系统1.0

思远企业网站管理系统是由思远负责人结合多年的开发精髓为企业量身订做的一套全国通用版本的企业网站 管理系统,该系统体积小,代码执行速度快,用户操作相当简单而深受大家的喜爱。 版本说明:程序采用asp.net(c#)+access(节约企业资源) 1:网站由后台全静态生成前台所有页面,简化操作,一键即可生成大型企业网站 2:网站栏目灵活控制:是为企业量身订做的企业网站,通过模板自由生成各行各业大型企业

思远企业网站管理系统1.0 0
查看详情 思远企业网站管理系统1.0

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

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
登录后复制
相关标签:
java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号