JavaScript灵活性举例分析

这篇文章主要介绍“JavaScript灵活性举例分析”,在日常操作中,相信很多人在JavaScript灵活性举例分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JavaScript灵活性举例分析”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

邵原网站制作公司哪家好,找创新互联公司!从网页设计、网站建设、微信开发、APP开发、自适应网站建设等网站项目制作,到程序开发,运营维护。创新互联公司于2013年开始到现在10年的时间,我们拥有了丰富的建站经验和运维经验,来保证我们的工作的顺利进行。专注于网站建设就选创新互联公司

首先,在 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灵活性举例分析”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注创新互联网站,小编会继续努力为大家带来更多实用的文章!


分享文章:JavaScript灵活性举例分析
网页地址:http://csdahua.cn/article/gghhjh.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流